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PREFACE 



This manual provides general informa- 
tion, an installation and interface 
guide, and programming information for 
the Advanced Micro Computer, Am95/6110 
Flexible Disk Controller board. Addi- 
tional information can be obtained from 
the following documents. 

Western Digital Corporation 
FD1771 A/B-01 Data Sheet 



Both active-high (positive true) and 
active-low (negative true) signals are 
discussed. To eliminate confusion and 
simplify the notation, the following 
signal convention is used. Whenever a 
signal is active-low, its mnemonic is 
followed by an asterisk (*). For ex- 
ample, MEMR* denotes an active-low sig- 
nal. Active-high signals are denoted 
without the asterisk. 



Advanced Micro Devices 
Am9517 Data Sheet 
Am9517 Application Note 
Am9085 Data Sheet 

This manual is intended for use by sys- 
tems engineering and programming per- 
sonnel. A minimum of tutorial informa- 
tion is included. Standard abbrevia- 
tions and acronyms are used in the 
text. 



The information in this manual is be- 
lieved to be accurate and complete at 
the time it was printed. However, AMC 
reserves the right to change specifica- 
tions without notice. No responsi- 
bility is assumed for errors that might 
appear in this manual. No part of this 
manual may be copied or reproduced in 
any form without prior written permis- 
sion from AMC. 
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CHAPTER 1 
GENERAL INFORMATION 



1-1. INTRODUCTION 

The Am95/6110 is a single density flop- 
py disk controller for up to four sel- 
ectable single or double sided floppy 
disk drives, using an Am9085 micro- 
processor based design which provides 
reliable and flexible functions. 
Features include: a 20-bit DMA address 
capability allowing it to address up to 
1 megabyte of main memory, drive write 
protection, automatic CRC generation 
and check, full IBM 3740 compatible 
soft sector formatting, automatic track 
seek verify, and head unloading after 
two idle disk rotations to assure long 
diskette life. An automatic bootstrap 
load from track 00, sector 01 
(jumper selectable) is done at system 
initialization without system processor 
intervention. 

The Am95/6110 is fully TTL compatible. 
It is provided with an adaptable inter- 
face to microprocessor systems com- 
prising an 8-bit parallel bus, 20-bit 
address bus, and appropriate control 
lines. An on-board DMA interface 
transfers data directly to or from ex- 
ternal memory and the disk control- 
ler. 



1-2. PHYSICAL DESCRIPTION 

The Am95/6110 Floppy Disk Controller 
board is a two layer printed circuit 
board. An 86-pin and 60-pin connector 
provide bus compatibility with AMC's 
System 8/8 and the Intel Multibus 1 " in 
either a Multi-master or Single-master 
bus configuration. Physical character- 
istics of the Am 95/6110 are: 



Board Dimensions 

Width 30.48 cm (12 inches) 
Depth 17.15 cm (6.75 inches) 
Thickness 1.50 cm (0.60 inches) 

Interface Connectors 

PI - 86 pin, .156 in pin spacing edge 

connector 
P2 - 60 pin, .10 in pin spacing edge 

connector 
P3 - 50 pin, .10 in pin spacing edge 

connector 
P4 - 50 pin, .10 in pin spacing edge 

connector 



Power Requirements 

vcc 
Vdd 
Vbb 

!CC 
*DD 



+ 5 V, + 5% 
+12 V, + 5% 
- 5 V, + 5% 

3 AMP 
300 mA 
150 mA 



Environmental Requirements 

Operating Temperature 0°C to 55°C 



Relative Humidity 



up to 90% 

without 

condensation 



1" Multibus is a 
Corporation 



trademark of Intel 



Storage Temperature -40°C to +75°C 



1-3. FUNCTIONAL DESCRIPTION 

The Am95/6110 Floppy Disk Controller 
(FDC) is an intelligent disk controller 
that accepts commands from a host com- 
puter via the system bus, and permits 
the host CPU/operating system to access 
data stored on a floppy diskette. Data 
is stored in random-access form. Data 
can be read from or new data written 
onto a selected location on the disk- 
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ette. Communication between the host 
CPU and the FDC is conducted over a 
standard Intel Multibus compatible 
system bus. 

The FDC and host CPU exchange informa- 
tion through the mailbox registers (R0 
-R4), associated with I/O ports (R0- 
R3.) Bits 2 through 7 of the address 
from the system bus are decoded and 
compared with the board address to de- 
termine if the command is intended for 
the FDC board. Bits and 1 are used 
to specify a particular mailbox regis- 
ter. The data for reading or writing on 
the floppy diskette is transferred un- 
der Direct Memory Access (DMA) control. 

When the host computer sends a command 
to the FDC, execution and control of 
the resulting operations are performed 
by the on-board Am9085 microprocessor, 
utilizing the DMA controller (Am9517) 
and the floppy disk controller 
(FD1771). 

The command set is used to invoke firm- 
ware residing in 2K of on-board PROM. 
Each command invokes a portion of the 
firmware. When executed, the various 
firmware routines perform the floppy 



disk controller functions. The FD1771 
floppy disk controller chip, controlled 
by the Am9085, selects a particular 
disk drive, accesses a predetermined 
location on that diskette, and either 
reads data from or writes data onto 
that diskette. Data read is separated, 
put into 8-bit bytes, and is either 
transferred into the buffer memory or 
sent byte-by-byte to a main memory 
whose location is designated by the 
DMA. Data transferred to the buffer 
memory can be sent to main memory by 
the DMA after the sector is completely 
read. Data can be read and transferred 
in sector or block (continuous sector) 
form. Data written onto the diskette 
goes to the FD1771 byte-by-byte in the 
same manner described for the read 
mode. The FD1771 serializes, formats, 
and sends the data to the specific 
location on the diskette to be written. 



Status, address, data, and control sig- 
nals for the internal operations of the 
FDC are routed on the internal address 
and data bus lines. The FDC board sta- 
tus register contents are loaded into 
R4 which can be examined by the host 
CPU. 
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CHAPTER 2 
INSTALLATION AND INTERFACE 



2-1. INTRODUCTION 

This chapter provides instructions for 
unpacking and preparing the Am 95/6110 
Board for connection to a micro- 
computer system. System Bus signal 
characteristics, connector pin assign- 
ments and timing information necessary 
to interface the FDC board to a CPU and 
the FDC board to a Floppy Disk Drive 
are also included in this chapter. 



2-2. UNPACKING AND INSPECTION 

Inspect the shipping carton immediately 
upon receipt for evidence of mishan- 
dling during transit. If the shipping 
carton is severely damaged or water- 
stained, request the carrier's agent to 
be present when the carton is opened. 
If the carrier's agent is not present 
when the carton is opened and the con- 
tents of the carton are damaged, keep 
the carton and packing material for the 
agent's inspection. Shipping damages 
should be immediately reported to the 
carrier. 



NOTE 

Do not attempt to service the 
board yourself as this will 
void the warranty. 

It is suggested that salvageable ship- 
ping cartons and packing materials be 
saved in case the product must be ship- 
ped in the future. 



2-3. PRE-INSTALLATION OPTION 
SELECTION 

Before connecting the FDC board to the 
microcomputer system, switches and 
jumpers must be set to the desired 
positions to select the features that 
are required to customize the board for 



its intended use. The following 
paragraphs provide information on 
switch and jumper selection. 



2-4. DATA BUS 

The FDC board can be interfaced to the 
host CPU through either an 8-bit or a 
16-bit system data bus. Jumpers and 
switches provided on the board must be 
placed in the proper position to con- 
figure the board for the data bus with 
which it is to be used. Jumper instal- 
lation for 8 or 16 bit data control is 
shown in table 2-1. When the jumper is 
installed between pins 34-38, the FDC 
is configured to operate with an 8-bit 
data bus. When the jumper is installed 
between pins 33-34, the FDC is config- 
ured for a 16-bit data bus, with DMA 
= addressing in the Low Order Byte. 
When the jumper is installed between 
34-35, the FDC is configured for a 16- 
bit data bus, with DMA = address- 
ing in the High Order Byte. 



2-5. BOARD SELECT SWITCHES 



Six two-position DIP 
through SW6) are used 
addresses to which the 
respond. As shown 



switches 
to select 
FDC board 
in table 



(SW1 

the 

will 

2-2, 

address bits 2 through 7 must cor- 
respond to switches SW1-SW6, respec- 
tively. A logical 1 on the port address 
bus corresponds to the on position of 
the board select switches. Address bus 
bits and 1 are decoded for the ex- 
ternal addresses of registers R0 
through R4. 



2-6. MEMORY CONTROL SELECTION 

To customize the FDC board for the spe- 
cific size of the E-PROMs being used, 
it is necessary to apply to the chip 
sockets the voltages and control sig- 
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TABLE 2-1. DATA BUS SELECTION. 



Data Bus 


Jumper Selection 
From To 


8-bit 


34 -38 


16-bit 


33 34 - DMA 0=0, Enable Low Byte 


16-bit 


34 35 - DMA 0=0, Enable High Byte 




- Jumper configuration for factory installed 


firmware 





TABLE 2-2. BOARD SELECT SWITCH SETTINGS. 



SWITCH 


ADDRESS 




I/OWC 




I/ORC 


NUMBER 


BIT 










SW6 


7 










SW5 


6 










SW4 


5 










SW3 


4 










SW2 


3 










SW1 


2 










Not Used 


1 





1 


1 


1 


Not Used 








1 


1 


1 


Register 


Selection 


R0 


Rl R2 


R3 


R4 



nals required by the chosen devices. 
The jumpers used to select these volt- 
ages and control signals are shown in 
table 2-3. The E-PROM devices can be 
either Am9708 (IK) or Am9716 (2K). No 
jumpers are- required to access off- 
board private memory. Off-board memory, 
in this context, is specifically pri- 
vate to the floppy disk controller and 
is not directly addressable by other 
bus masters in the system. 



2-7. INTERRUPT SELECTION 

The FDC board is capable of generating 
a system interrupt on one of eight 
interrupt lines to be utilized as the 
system designer wishes. The interrupt 
is brought off-board through connector 
PI. The jumper options available for 



TABLE 2-3. MEMORY CONFIGURATION. 



Memory 
Device 



Am9708 
IK x 8 

Am9716 
2K x 8 



Jumper Selection 
From To 



81 82 

80 79 

77 78 

111 112 

30 31 

115 116 



81 
80 
77 

111 
29 

113 



83 
82 
79 

114 
30 

115 



Jumper configuration 

for factory installed firm- 
ware 
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connecting the 
edge connector 
2-4. 



interrupt lines to the 
(PI) are shown in table 



The FDC, Am9085 CPU interrupt jumper 
options are also shown in table 2-4. 
For normal system bus operation with 
the standard OEM firmware installed, 
jumpers are configured as shown. 



2-9. Am9085 CPU, SID JUMPER 

The Am9085 serial input data (SID) line 
is tested by the resident firmware 
and the results determine if an auto 
boot will be implemented. When a jumper 
is installed between SID (86) and 
Ground (84), SID = 0, the auto boot 
feature is selected. When this jumper 
is not installed, at reset the firmware 



TABLE 2-4. INTERRUPT JUMPERS. 



Interrupt Sources 



Am9085^ 



INTREQ 

EOPINT 

URINT 

COMIN 

GROUND 

GROUND 



Jumpers 
Source Interrupt 



59 

60 

57 

58- 

55 

56 

53 

54 



67 
68 
65 
■66 
63 
64 
61 
62 



88 87 

75 76 
73 74 
71 72 

69 70 

97— 98 



System Bus 
Interrupt 



INT0 
INT1 
INT2 
INT3 
INT4 
I.NT5 
INT6 
INT7 



Jl Pin 



41 
42 
39 
40 
37 
38 
35 
36 



Am9085PU 
Interrupt 



RST 7.5 
RST 6.5 
RST 5.5 
TRAP 
TRAP 
INTR 



normal jumper configuration for factory installed firmware 

*FDC Board interrupt to host computer. 



2-8. CPU CLOCK FREQUENCY SELECT 

The input clock frequency to the Am9085 
is jumper selectable for either 4MHz or 
8MHz (for 2MHz or 4MHz boards 
respectively). Jumper installation 
selection is shown in table 2-5. If 
the 8MHz option is used, some of the 
chips on the FDC must be replaced with 
devices that operate at the higher 
frequency. The standard OEM FDC board 
(2MHz Am9085) is shipped with the 4MHz 
clock jumper option installed. 



TABLE 2-5. CPU CLOCK FREQUENCY 
SELECTION. 



Frequency 


Jumper Selection 
From To 


8MHz 
4MHz 


41 42 
43 42 


normal jumper configura- 
tion for factory installed firmware 
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performs a status request operation on 
unit zero and makes the results avail- 
able to the host system boot program. 
On OEM boards, this jumper is not in- 
stalled. The SID/SOD lines are not 
brought out to connector pins and 
therefore are not customer usable. 



2-11. DMA ACKNOWLEDGE 
(DACK0-DACK3) 

DMA Acknowledge is used to notify an 
individual peripheral that it has been 
granted a DMA cycle. Table 2-7 shows 
the jumper configuration to utilize 
these lines. 



2-10. DMA REQUEST SOURCE 
(DREQ0-DREQ3) 

The direct memory access (DMA) (Am9517) 
request lines are individual asynchron- 
ous channel request inputs used by 
peripheral circuits to obtain DMA serv- 
ice. Table 2-6 shows the jumper options 
used for DMA channel selection. Also 
shown is the jumper configuration for 
an OEM board with the standard firmware 
instal led. 



2-12. READY/DMA SPEED SELECTION 

The ready input is used to extend mem- 
ory read and write pulses from the 
Am9517 to synchronize the DMA with slow 
memory. A jumper must be installed be- 
tween pins 4 and 3 to enable the Ready 
Control. Table 2-8 shows the jumper 
selections for FDC data transfers. 
When the Ready signal is activated by 
an external memory (via the system 



TABLE 2-6. DMA REQUEST. 



Request Source 


Jumper Selection 
From To 


Data Channel 


TXINT 


89 93 


DREQ3 


RXINT 


90 / 94 
92 / 


DREQ2 


FDDRQ 


DREQ1 


FDDRQ 


DREQ0 


normal jumper configuration for 

firmware 


factory installed 



TABLE 2-7. DMA ACKNOWLEDGE. 



Source 


Jumper Selection 
From To 


Acknowledge 


DACK3 
DACK2 
DACKl 
DACK0 


105 x 109 
106 v \ 110 

103 \ x 107 

104 x 108 


IDACK3 
IDACK2 
IDACKl 
IDACK0 


normal jumper configuration for 

factory installed firmware 
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TABLE 2-8. DMA SPEED SELECTION. 



Control 


Jumper 


Selection 




From 


To 


Enable Ready Control 


4___ 


3 


EXT Ready Control 


12— 


17 


Bypass Delay (INT) 


22 


17 


Delay (Ready Pulse Width) 






1.0 usee (.511ms/128 byte) 


8 


13 


1.0 usee (.511ms/128 byte) 


9 


14 


1.0 usee (.511ms/128 byte) 


10 


15 


1.5 usee (.575ms/128 byte) 


11 


16 


1.5 usee ( .575ms/128 byte) 


21 


16 


1.5 usee (.575ms/128 byte) 


20 


15 


1.5 usee (.575ms/128 byte) 


19 


14 


1.5 usee ( .575ms/128 byte) 


18 


13 




nfigurati 


on for 


NUMIIdl JUUipcr LU 


factory installed firmware 







bus), a jumper is placed between pins 
12 and 17 (IACK) to circumvent all of 
the delay logic. When a delay is not 
required, a jumper is installed between 
pins 22 and 17. 



2-13. END-OF-PROCESS FLIP/FLOP 

The End-of-Process flip/flop is normal- 
ly set by the E0P output from the DMA 
controller; however, when a jumper is 
installed between pins 101 and 102, the 
E0P flip/flop can be set as a result of 
the INTREQ (FD1771). When this jumper 
is installed, either E0P (Am9517) or 
INTREQ (FD1771) sets the flip/flop. 
The OEM version of the FDC board is 
shipped without this jumper installed. 



2-14. POWER-ON HOLD 

The power-on hold selection is provided 
to permit the host CPU to be placed in 
a "hold" state until the FDC releases 



it to begin execution. The firmware 
supplied with the FDC provides the 
ability for track-0, sector-0 to be 
automatically read into location zero 
(0) of host memory to provide an "auto- 
boot" capability. When the auto boot 
is desired, a jumper is installed be- 
tween pins 5 and 6. When power-on hold 
is not required, with no auto boot, the 
jumper is installed between pins 6 and 
7. On OEM boards (with the standard 
firmware) the jumper is installed be- 
tween pins 6 and 7. 

2-15. HOLD REQUEST/BUS 
PRIORITY IN 

The FDC board is configured such that 
the Hold Request signal out for a sin- 
gle master system bus can be either ac- 
tive high or active low. The jumper can 
be moved for operation using a multi- 
master system bus, as shown in table 



2-9, which 
tion. 



is the standard configura- 



2-5 



TABLE 2-9. BUS PRIORITY IN/HOLD. 



Master 


Hold Request 


Jumper Selection 
From To 


Single 


Active High 


48 49 




Active Low 


48 52 


Multi 


Active Low 


48 47 


normal jumper conf 


iguration for factory 


installed firmware 





2-16. DATA SEPARATOR CLOCK 
SELECT 

The external data separator has a 
jumper-selectable clock frequency of 
4MHz. When using the external data 
separator, install a jumper between 
pins 129 and 131 for a 4MHz clock. An 
8MHz test point is available at Pin 
134. The OEM configuration is jumpered 
to operate with an external data 
separator and a 4MHz clock. 



2-17. FD1771 FLOPPY DISK 
CONTROLLER CLOCK 

The FD1771 Floppy Disk Controller has 
two jumper-selectable clock frequen- 
cies: 2MHz and 1MHz. Jumper selections 
for each frequency are defined in table 
2-10. The standard OEM board is ship- 
ped with the 2MHz option installed, for 
a standard 8 inch floppy disk drive. 



2-18. DISK INITIALIZATION (DINT) 

This input is sampled whenever a write 
command is executed. If DINT = 0, the 
operation is terminated and the Write 
Protect Status bit is set. For the OEM 
configuration, this input on the FDC 
board is jumpered to logic high by con- 
necting pins 127 and 128. 



TABLE 2-10. FD1771 CLOCK FREQUENCY. 


Frequency 


Jumper Selection 
From To 


2MHz 
1MHz 


130 132 

133 132 


normal jumper configuration for 

factory installed firmware 



on the HLT input, the head is assumed 
to be engaged. Table 2-11 shows the 
different jumper options available to 
activate this input. On the OEM con- 
figuration of the FDC the HLT input is 
jumpered to the HLD signal , which 
provides a 35ms delay to allow the head 
load to be accomplished. 



TABLE 2-11. HEAD LOAD TIMING. 



Time Delay 



HLD 10ms 

HLD Seek Complete 

HLD 35ms 



Jumper Selection 
From To 



123 124 
126 124 
125 124 



normal jumper configuration for 

factory installed firmware 



2-19. HEAD LOAD TIMING (HLT) 

The HLT input of the FD1771 is sampled 
10ms after activating the head load 
output. When a logic high is sampled 



2-20. AUTO RESET 

The FDC board 
and jumpers 



Reset line 



is configured with logic 
such that the INIT system 
to the system bus can be 
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activated either by the on-board Am9085 
(at power up or manual reset), or under 
software control. Table 2-12 shows the 
jumper selections for these options. 
The OEM board is configured such that, 
with activation of the OE01 line, the 
system reset line goes low (active) for 
eight clock periods. 

2-21 . BUS CLOCK 

Availability of a 4MHz or 8MHz external 
clock is provided for the system bus by 
installation of jumpers. For the 4MHz 
bus clock, install a jumper between 
pins 36 and 37. For the 8MHz bus 
clock, install a jumper between pins 32 
and 37. The OEM version of the FDC is 
shipped without any jumper installed. 
No jumpers are required when the bus 
clock is from another bus master. 



2-22. BUS MASTER CONTROL/HOLD 
ACKNOWLEDGE 

The FDC board is jumper-selectable to 
operate in a multi -master or single 
master system bus environment. When 
operating in a single master environ- 
ment the HACK signal can be selected 
for either an active high or active low 
state. Jumper selections for this op- 



tion are defined in table 2-13. The 
OEM board is jumpered for multi -master 
operation. 



2-23. HEAD LOAD CONTROL 

Jumpers are provided such that a head 
load can be implemented by the on-board 
firmware or by the FD 1771 chip. When 
a jumper is installed between pins 139 
and 140, drive select may be enabled 
either with the 1771 HEAD LOAD signal 
or be enabled under firmware control. 
When a jumper is installed between pins 
138 and 139, firmware controls the 
drive select. The OEM version of the 
board has a jumper installed between 
pins 139 and 140. 



2-24. BUS PRIORITY OUT (BPRO) 
DAISY CHAIN 

This system-bus signal is used with a 
serial priority resolution scheme, and 
is used to pass the bus priority chain 
to the lower priority bus master. When 
more than one board capable of being a 
master is on the system bus, this 
jumper is installed between pins 39 and 
40. The OEM board has this jumper 
installed. 



TABLE 2-12. RESET CONTROL. 



Reset Control 


Set 


Reset 


Jumper Installation 
From To 


Software 

Software 
Am9085 


OE01 

OE01 
RST/0E1 


8 clock 
pulses 

IE01 

8 clock 
pulses 


24 25 

27 26 

24 25 
27 28 

23 25 
27 26 


normal jumper configuration for 

factory installed firmware 
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TABLE 2-13. BUS MASTER CONTROL. 



System Bus 



Jumper Installation 
From To 



Hold Acknowledge 



Multi -Master 



Single-Master 



45- 
46- 

44 
51 



■50 
•51 

45 
45 



N/A 
N/A 

Active Low 
Active High 



normal jumper configuration for factory installed 

firmware 



2-25. INSTALLATION 

After using the on-board switches and 

jumpers to tailor the FDC board for its 

intended use, insert the board into the 

system backplane and apply power. If 

the board fails to operate, notify the 
Advanced Micro Computers' service man- 
ager. 



NOTE 

Do not return the board to AMC 
under any circumstances with- 
out an approved return mater- 
ial authorization number 
(RMA), which will be provided 
by the service manager. 



2-26. INTERFACE SIGNAL 
DESCRIPTION 

This section describes the signals that 
interface the FDC board to the host 
central processing unit and its peri- 
pheral devices. Signals shown with an 
asterisk (*) following the signal name 
are active low signals. Active high 
signals appear without an asterisk suf- 
fix. 



2-27. CPU/SYSTEM BUS INTERFACE 

Connector PI is an 86-pin double-sided 
edge connector that interfaces the FDC 



board to other system components. Nor- 
mally, connector PI plugs into a back- 
plane wiring configuration called a 
system bus. Pin assignments for Con- 
nector PI are listed in table 2-14. 



2-28. Address (ADRO* through ADR13*) 

The 20-bit address from the system bus 
is used by the on-board DMA to access 
up to 1 megabyte of memory ADRO* is 
the least significant bit and ADR13* is 
the most significant address bit. 
Address bits 2 through 7 (ADR2*-ADR7*) 
are compared with the board address 
select switches; only an address that 
matches the select switch settings is 
recognized by the FDC board. Address 
bits and 1 are used to access various 
on-board register locations for 
externally-generated I/O read/write 
operations. 



2-29. Data (DATO* through DATF*) 

Sixteen bidirectional data lines are 
used to transmit or receive information 
between the FDC and an external (host) 
system. These lines are driven by the 
master on write operations and by the 
addressed slave (memory or I/O) on read 
operations. The system bus can handle 
both 8 or 16 bit data transfers. Only 
bits DATO* through DAT7* are used when 
executing eight-bit transfers (DATO* is 
the least significant bit). 
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TABLE 2-14. SYSTEM BUS CONNECTOR P1 PIN ASSIGNMENTS. 







(Component 


: Side) 




(Circuit Side) 




Pin 


Mnemonic 


Description 


Pin 


Mnemonic 


Description 




1 


GND 


Signal GND 


2 


GND 


Singal GND 




3 


+5 


+5 VDC 


4 


+5 


+5 VDC 


Power 


5 


+5 


+5 VDC 


6 


+5 


+5 VDC 


Suppl ies 


7 


+12 


+12 VDC 


8 


+12 


+12 VDC 




9 


-5 


-5 VDC 


10 


-5 


-5 VDC 




11 


GND 


Signal GND 


12 


GND 


Signal GND 




13 


BCLK* 


Bus Clock 


14 


INIT* 


Initial ize 




15 


BPRN* 


Bus Priority In 


16 


BPRO* 


Bus Priority Out 




17 


BUSY* 


Bus Busy 


18 


BREQ* 


Bus Request 




19 


MRDC* 


Mem Read Command 


20 


MWTC* 


Mem Write Command 


Bus 


21 


IORC* 


I/O Read Command 


22 


IOWC* 


I/O Write Command 


Controls 


23 


XACK* 


XFER Acknowledge 


24 


INH1* 


Inhibit 1 (RAM) 




25 


AACK* 


Not Used 


26 


INH2* 


Inhibit 2 (ROM) 




27 


BHEN* 


Byte High Enable 


28 


ADR10* 






29 


CBRQ* 


Common BUs Request 


30 


ADR 11* 


Address Bus 




31 


CCLK* 


Constant Clock 


32 


ADR12* 






33 


INTA* 


Interrupt Acknowledge 


34 


ADR13* 






35 


INT6* 




36 


INT7* 




Interrupts 


37 


INT4* 


Parallel Interrupt 


38 


INT5* 


Parallel Interrupt 




39 


INT2* 


Requests 


40 


INT3* 


Requests 




41 


INTO* 




42 


INT1* 






43 


ADRE* 




44 


ADRF* 






45 


ADRC* 




46 


ADRD* 






47 


ADRA* 




48 


ADRB* 




Addresses 


49 


ADR8* 


Address Bus 


50 


ADR 9* 


Address Bus 




51 


ADR6* 




52 


ADR7* 






53 


ADR4* 




54 


ADR 5* 






55 


ADR2* 




56 


ADR3* 






57 


ADRO* 




58 


ADR1* 






59 


DATE* 




60 


DATF* 






61 


DATC* 




62 


DATD* 






63 


DATA* 


Data Bus 


64 


DATB* 


Data Bus 


Data 


65 


DAT8* 




66 


DAT9* 






67 


DAT6* 




68 


DAT7* 






69 


DAT4* 




70 


DAT5* 






71 


DAT2* 




72 


DAT3* 






73 


DATO* 




74 


DAT1* 






75 


GND 


Signal GND 


76 


GND 


Signal GND 




77 


-- 


— 


78 


— 


— 


Power 


79 


-12 


-12 VDC 


80 


-12 


-12 VDC 


Supplies 


81 


+5 


+5 VDC 


82 


+5* 


+5 VDC 




83 


+5 


+5 VDC 


84 


+5 


+5 VDC 




85 


GND 


Signal GND 


86 


GND 


Signal GND 
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2-30. Interrupt Request Lines 
(INTO* through INT7*) 

These eight lines are used to connect 
jumper- select able interrupts to the 
data bus. The on-board Am9085- 
generated interrupt can be connected to 
any of the eight interrupt request 
inputs. INTO* is the highest priority 
interrupt and INT7* is the lowest 
priority. 



2-31. Initialization 

This signal from the system bus resets 
the board to a known internal state. 



2-32. Input/Output Read Command 
(IORC*) 

The IORC* signal is used for I/O input 
control. The I/O port address is on 
the system address bus. IORC*, along 
with a port address recognized by the 
FDC, is a request to read data from the 
addressed FDC register. 



is generated by the FDC to 
into the main (host) memory. 



write data 



2-36. Transfer Acknowledge (XACK*) 



This signal is 
system bus 
specified read 
been completed 



sent to the FDC from the 
indicating that the 
or write operation has 
and that data has been 
placed onto, or accepted from, the sys- 
tem bus data 1 ines. 



2-37. FLOPPY DISK DRIVE INTERFACE 

Connector P4 is a 50-pin double-sided 
edge connector that interfaces the FDC 
board to the floppy disk drives. The 
floppy disks are connected together 
through a 50-pin flat cable to P4 of 
the FDC board and additional disk 
drives are connected in daisy chain 
fashion, drive-to-drive. Pin assign- 
ments for Connector P4 are listed in 
table 2-15. The last drive connected 
to the string must have a terminator 
instal led. 



2-33. Input/Output Write Command 
(IOWC*) 

The IOWC* signal indicates that an I/O 
port address is on the system bus ad- 
dress lines. The address and data must 
be stable on the system bus 50ns prior 
to activation of the write command. 



2-34. Memory Read Command (MRDC*) 

The MRDC* signal performs in the same 
manner as the IORC* signal except that 
a memory address is on the address bus 
instead of an I/O port address. MRDC* 
is generated by the FDC to read data 
from main (host) memory. 



2-38. Track Greater Than 43 (TG43*) 

TG43* active indicates to the disk 
drive that the read/write head of the 
selected drive is positioned between 
tracks 44 and 76. Activation of the 
signal occurs only during a read or 
write command. 



2-39. Write Protect (WRPT*) 

When a write command is issued by the 

FDC, the write protect signal is 

sampled by the FD1771. A logic low 

terminates the command and sets the 
write protect status bit. 



2-35. Memory Write Command (MWTC*) 

The MWTC* signal performs in the same 
manner as the IOWC* signal except that 
a memory address is on the address bus 
instead of an I/O port address. MWTC* 



2-40. Track 00 (TROO*) 

At a logic low, the TROO* signal from 
the disk drive indicates the read/write 
head is positioned at track 00. 
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TABLE 2-15. P4 CONNECTOR PIN ASSIGNMENT. 



Component Side 


Circuit Side 


Pin 


Mnemonic 


Description 


Pin 


Mnemonic 


Description 


2 

4 
6 
8 
10 
12 
14 
16 
18 
20 
22 
24 
26 
28 
30 
32 
34 
36 
38 
40 
42 
44 
46 
48 
50 


GND 
GND 
TG43 

* 2 SIDED 

* DISK CHANGE 

* SIDE SELECT 

* IN USE 

* HEAD LOAD 
INDEX 

* READY 

* Sector 
DS01 
DS02 
DS03 
DS04 
DIR 
STEP 
WD 

WG 

TR00 

WPRT 

RD 

SEP DATA 

SEP CLK 


Signal Ground 
Signal Ground 
Track Greater than 43 

2 Sided 

Index Pulse 
Ready 

Sector (851 Only) 
Drive 1 Select 
Drive 2 Select 
Drive 3 Select 
Drive 4 Select 
Direction 
Step 

Write Data 
Write Gate 
Track00 
Write Protect 
Read Data 
Separated Data 
Separated Clock 


1 
3 
5 
7 
9 
11 
13 
15 
17 
19 
21 
23 
25 
27 
29 
31 
33 
35 
37 
39 
41 
43 
45 
47 
49 


GND 
GND 


Signal Ground 
Signal Ground 


*These signals are defined in more detail in the Shugart SA800/801 OEM Manual. 



2-41. Index Pulse (IP*) 

The index pulse is a lOusec logic low 
pulse which indicates to the FDC that 
the selected disk drive read/write head 
has sensed the index notch on the dis- 
kette. 



2-42. Ready 

This signal from the selected floppy 
disk drive indicates its ready status 
and is examined prior to initiating a 
read or write command by the FD1771. A 
logic-low at P4 (READY*) indicates that 
the drive is ready. If the ready signal 
is high, no read or write operation is 
performed and an interrupt is gener- 



ated. A seek operation can be performed 
regardless of the ready signal condi- 
tion. 



2-43. Write Gate (WG) 

The write gate signal from the FDC 
board (P4, WRITE GATE*) is activated 
(logic-low) to the selected drive when 
a write operation is performed. 



2-44. Write Data (WD) 

The write data stream is a serial 
of data and clock pulses, each 
being 500ns in duration. 



train 
pulse 
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2-45. Direction (DIRC) 

The direction signal is either a logic 
high or low that indicates to the disk 
drive the direction the heads must move 
when the step signal activates. A 
logic-high at P4 (DIR) causes the head 
to move out (toward track 00); and a 
logic low causes the head to move in 
(toward track 76). 



2-46. Step (PH1/STEP) 

The step signal is a positive pulse of 
4usec duration that causes the disk 
drive heads to move one track in or out 
(depending on the state of the DIRC 
signal ) . 



2-47. 2 Sided 

This logic-high signal indicates that a 
double-sided drive is in use. 



NOTE 

This same pin would be used to 
indicate seek COMPLETE when 
used with persi drive. 



2-48. Read Data 

Raw data (clock and data together) from 
the diskette come to the FDC board via 
the READ DATA line and are processed by 
the on-board data separator where the 
clock data pulses are separated and 
gated to the FD1771. 



2-49. Drive Select (DS01*-DSQ4*) 

Four drive select lines (DS01*-DS04*) 
go from the FDC board to the disk 
drives to select a specific drive. 
Only one of these lines is active (low) 
at a time. Each drive is address 
programmed and is set to a location 1 
through 4. 
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CHAPTER 3 
OPERATION AND PROGRAMMING 



3-1. INTRODUCTION 

The floppy disk controller board oper- 
ates under command of the host CPU. 
The host CPU can interrogate the FDC by 
reading the status byte in the on-board 
status register. The host CPU can also 
set-up operating parameters by writing 
the data into three mail -box registers 
in the FDC and initiating one of eleven 
operations by writing a command code 
into a fourth mail -box register 
(referred to as the command register), 
command is initiated, the 
CPU (under control of the 
continues without host CPU 
until the operation is 



Once a 

on-board 

firmware) 

intervention 

complete. 



Each FDC 
figured 
jumpers 
address 
may be 
Placement of 
chapter 2. 



board may be uniquely con- 
through the placement of 
on the board. The I/O port 
to which the FDC board responds 
selected by on-board switches, 
jumpers is discussed in 



The FDC provides two interfaces, one to 
the host CPU, and the other to the 
floppy disk unit. The host CPU/FDC 
board interface consists of an INTEL 
MULTIBUS through which commands and 
data are passed from the host CPU to 
the FDC. Status, disk data, and 20-bit 
DMA addresses are passed back to the 
host CPU. The floppy disk interface 
consists of head positioning control 
signals, write gate control signals, 
and data transfer lines. Each function 
is hard-wired to the appropriate disk 
drive. 



3-2. BOARD SELECTION 

The port address of the FDC board is 
set-up by six two-position DIP 
switches. When set, these switches 
(SW1 through SW6) select the address to 



which the FDC board will respond. 
These switches correspond to address 
bits 2 through 7, respectively. 
Address bits and 1 select the I/O 
port through which parameters are 
passed. 



3-3. FUNCTIONAL CONFIGURATION 

Jumpers may be required on the FDC 
board in positions other than those 
installed at the factory. The place- 
ment, definition, and uses of the jum- 
per selectable features are included in 
chapter 2. The manner in which they are 
installed, to accomodate factory 
installed firmware, is also included. 
The jumper positions described in 
chapter 2 should be verified before the 
board is put into service. 



3-4. FIRMWARE DESCRIPTION 

The Am95/6110 Floppy Disk Controller 
firmware (PN-02050068) resides in the 
Am95/6110 controller E-PROMs. A 
description of the factory installed 
firmware is shown as a listing in table 
3-1. 

The firmware consists of program 
routines for the on-board Am9085A CPU. 
These routines interrogate the mail -box 
registers, set up operating parameters, 
determine which of the eleven commands 
is requested, implement the command, 
exercise the FD1771 Floppy Disk Format- 
ter/Controller, and the Am9517 Multi- 
mode DMA Controller to produce floppy 
disk operating signals, and perform 
other FDC board operations. 

Briefly, the firmware and Am9085 CPU 
function as follows. Writing a command 
into the command register (R3) sets the 
Command Bit flip-flop on the FDC board. 
This causes the on-board CPU to process 
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TABLE 3-1. 



amc macro assem 1 .0 
i?lf = 



0030 
0031 

0032 
££33 



000 
0001 
0002 
0003 



0048 
0049 
004A 
004E 
004D 
004E 



#001 AMC 95/6110 SINGLE DENSITY FTC VI. 3 



JSET TO 6110 OE 6120 
'AMC 95/6120 SINGLE/DOUBLE TENSITY FDC VI. 0' 
'AMC 95/6110 SINGLE DENSITY FDC VI. 3' 



TYPE 


EQU 


6110 


IF 


TYPE 


EQ 612£ 




TITLE 


'AMC 95 




ELSE 






TITLE 


'AMC 95 




ENDIF 






PAGE 


43 


$-MACRO 






SIM 


MACRO 


VALUE 




MVI 


A, VALUE 




DB 


30H 




EN DM 




RIM 


MACRO 






LB 


20H 




ENLM 






HOST 


REGISTERS 


R0 


EQU 


30h 


Rl 


EOU 


31H 


R2 


EQU 


32E 


R3 


EQU 


33H 




1771 


REGISTERS 


FDC ST 


EQU 





IDTRK 


EQU 


1 


FDSEC 


EQU 


2 


FEAT A 


EQU 


3 




FDC REGISTERS 


CMDSTA 


EQU 


48H 


RESET 


EQU 


49E 


SEGMT 


EQU 


4AH 


CMDEES 


EQU 


4BE 


DRSEL 


EQU 


4DH 


RELSE 


EQU 


4EH 




1771 


COMMANDS 



JUMT/PASE 
JTRACK/MSB ADDRESS 
JSECTOR/LSB ADDRESS 
J COMMAND/STATUS 



JCOMMAND/STATUS 

JTRACK 

JSECTOR 

JDATA-TRACK FOR SEEK 



JCGMMANr/STATUS 

;SYSTEM 29 RESET 

J ADDRESS PAGE 

J COMMAND RESET 

:UNIT SELECT 

J SYSTEM 29 RELEASE 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 



#002 



AMC 95/6110 SINGLE TENSITY FPC VI. 3 



8 ere 

000 A 
001E 
0068 
00A8 
00F4 
005A 
0016 
0010 



0010 
0011 
0012 
0013 
0014 
0015 
0016 
0017 
0019 
0019 
001E 
001C 
001 P 
001E 



009C 
00FC 



FRCIN 


EOU 


0D0H 


jforce STATUS I 


RESTR 


ECU 


0AH 


JRESTORE 


SEEK 


EQU 


1EE 


:SEEK TRACK 


REAP 


EQU 


B8H 


JREAP SECTOR 


fchlTE 


EQU 


0A8E 


JWRITE SECTOR 


WRTRK 


EQU 


0F4H 


JWRITE TRACK 


STEP 


EQU 


5AH 


JSTEP IN 


LPREP 


EQU 


16E 


J LOAD HEAP 


UNLOE 


EQU 


10H 


JUNLOAP HEAP 


5 
J 


LMA PORTS 




PM0AP 


EQU 


10H 


; CHANNEL APPRESS 


PM0WC 


EQU 


UK 


; CHANNEL WORD COUNT 


PM1AP 


EQU 


12H 


JCHANNEL 1 APPRESS 


DM1WC 


EQU 


13H 


JCHANNEL 1 WORP COUNT 


DM2 AD 


EQU 


14E 


JCHANNEL 2 APPRESS 


PM2WC 


EQU 


15H 


; CHANNEL 2 WORP COUNT 


PM3AP 


EQU 


16H 


JCHANNEL 3 APPRESS 


EM3WC 


EQU 


17H 


JCHANNEL 3 WORP COUNT 


PMCST 


EQU 


18H 


JCOMMANP/STATUS 


PMREQ 


EQU 


19H 


JREQUEST 


PMMPE 


EQU 


1BH 


J MOPE 


PMBFF 


EQU 


1CH 


JEYTE FLIP-FLOP 


PMCLR 


EQU 


1UH 


JRESET 


PMMSK 


EQU 


1FH 


J MASK 


i 
J 


ERROR MASKS 




RPMSK 


EQU 


9CH 


J REAP ERROR 


WRMSK 


EQU 


0FCH 


JWRITE ERROR 




REQUEST 


FORMATS 






HOME 


R0=UNIT 








R3=REQUEST FUNCTION 




SETPAR 


R0=UNIT 
R1=TRACK 








R2=SECT0R(2-7TE BIT SET TO FO 



- 6120 ONLY) 



R3=REQUEST FUNCTION 1 
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TABLE 3-1. (Cont.) 



S.MC MAC BO ASSEM 1.0 



#003 Arc ps/ene single tensity fdc 71.3 

STATUS 



R0=UNIT 

R3=HE0UEST FUNCTION 2 

R3=RE0UEST FUNCTION 3 

R0=UNIT 

R3-REQUEST FUNCTION 4 

R3=REQUEST FUNCTION 5 

R3=KEQUEST FUNCTION 6 

R3=REQUEST FUNCTION 7 

R0=PAGE(SEGMENT) 
R1=MSB DATA ADDRESS 
R2=LSB FATA AIDE ESS 
R3=REQUEST FUNCTION 4X 

R0=PAGE( SEGMENT) 
E1=MSB DATA ADDRESS 
R2=LSB DATA ADDRESS 
R3=REQUEST FUNCTION 9X 

R0=PAGE( SEGMENT) 
R1=MSB PROGRAM ADDRESS 
R2=LSE PROGRAM ADDRESS 
R3=EEQUEST FUNCTION CX 

X=0-63 (PLUS ONE FOR READ/WRITE SECTORS) 

(PLUS ONE TIMES 64 FOR USER PROGRAM LENGTH IN BYTES) 

STATUS IS RETURNED IN R3 AS FOLLOWS: 

BIT 0=SEEK CRC ERROR 

1-SEEK ERROR 

2=L0ST EATA OR WRITE FAULT 

3=READ/WRITE CRC ERROR(SET TO 1 FOR HOME AND 6120 CONTROLLER - ELSE FO^ d 
4=SECTOR NOT FOUND - SIDE FOR HOME ANT STATUS REQUESTS 
5=WRITE PROTECT 
6=DEVICE NOT READY 
7=0?ERATI0N COMPLETE 



CLRINT 
INIDSK 

INTUNT 
INTTRK 
INTSEC 
READ 

WRITE 

EXECUTE 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 



#004 



AMC 95/6110 SINGLE TENSITY FIC VI. 3 



BITS 0-1 AND 2-4 ARE MUTUALLY EXCLUSIVE THUS: 
BITS AND 2=ILLEGAL REQUEST FUNCTION 

1 AND 2=TIME-0UT ON DEVICE BUSY Or. LOST INTERRUPT 

UNIT FORMAT: 

BIT 0-l=UNIT 0-3 

2=SIBE 0=0, 1=1 

3=DEN5ITY 0=SINGLE, l=DOUBLE 

4=RETRY 0=NONE, 1=9 FOR READ/WRITE, 5 FOR SEEK/HOME 

5=BUFFERING 0=EISK TO HOST, 1=DISK TO BUFFFR TO HOST 

6=INTERRUPT REQUEST 0=NONE, 1=INTERRUPT HOST 

7=INTERLACE, 0=1/1, 1=2/1 



0000 


= 


PORG 


FQU 





? PROGRAM OKIGIN 


0C00 


= 


P. A MAD 


EQU 


0C00H 


JDATA ORIGIN 


0000 




» 


ORG 


PORG 










I PL RAM 


TEST - UP/DOWN FF-00 PATTERN-(B KEEPS E 


0000 


3ED0 




MVI 


A,FRCIN 




0002 


D300 




OUT 


FDCST 


TERMINATE 1771 ACTIVITY 


0004 


01FF0F 




LXI 


B,0FFFH 




0007 


73 




MOV 


A,B 




0006 


1-332 




CUT 


R3 


INITIALLY SET ALL ERRORS 


000 A 


110004 




LXI 


D, 1024 




000D 


210010 




LXI 


H,RAMAD+ 


1024 


0010 


2B 


FILL 


DCX 


H 


INITIALLY FILL ALL RAM WITH FF 


0011 


71 




MOV 


M,C 




2012 


IB 




DCX 


D 




0013 


7A 




MOV 


A,D 




0014 


B3 




ORA 


F 




0015 


C21000 




JNZ 


FILL 




0018 


1604 




MVI 


D.4 




001A 


7E 


UPF 


MOV 


A,M 


? CHECK FOR FF AND SET 00 UP 


00 IB 


91 




SUB 


C 




001 C 


C26900 




JNZ 


PROM 




001F 


77 




MOV 


M,A 




0020 


23 




INX 


H 




0021 


IB 




DCX 


L 




0022 


7B 




MOV 


A,E 




0023 


B2 




ORA 


D 




0024 


C21A00 




JNZ 


UPF 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSFM 1.0 #005 



AMC 95/5110 SINGLE DENSITY FDC VI. 3 



0027 


21000C 




LXI 


H, HAMAD 






002A 


1604 




MVI 


D,4 






002C 


7E 


UPZ 


MOV 


A,M 


; CHECK FOR 00 AND 


SET FF U? 


002D 


B7 




ORA 


A. 






002E 


C 26900 




JNZ 


PROM 






0031 


71 




MOV 


M.C 






0032 


23 




INX 


p 






0033 


IE 




DCX 


D 






0034 


7A 




MCV 


A,r 






0035 


B3 




ORA 


E 






0036 


C 34000 




JMP 


DNI 






0039 






ORG 


39H 






0039 


C37001 


RETURN 


JMP 


CMDLP 


JFOR USER PROGRAM 


RETURN 






> 


INTERRUPT 7.5 






003C 


CI 


» 


POP 


D 


5 CLEAR KST RETURN 




003D 


BB00 




IN 


FDCST 






003F 


C9 




RET 








£040 


C22C00 


DM 


JNZ 


UPZ 






0043 


1604 




MVI 


D,4 






0045 


2B 


DNF 


DCX 


E 


5 CHECK FOR FF AND 


SET 00 DOWN 


0046 


75 




MOV 


A,M 






004? 


91 




SUB 


C 






0048 


C26900 




JNZ 


PROM 






004B 


77 




MOV 


M,A 






004C 


IB 




rex 


D 






004D 


7A 




MOV 


A,D 






004E 


B3 




ORA 


E 






004F 


C24500 




JNZ 


DNF 






0052 


210010 




LXI 


E.RAMAD+ 


1024 




0055 


1604 




MVI 


D,4 






0057 


2B 


DNZ 


DCX 


H 


J CHECK FOR 00 AND 


SET FF DOWN 


0058 


7i; 




MOV 


A,M 






0059 


B7 




ORA 


A 






005A 


C26900 




JNZ 


PROM 






005D 


71 




MOV 


M,C 






005E 


IE 




DCX 


D 






005F 


7A 




MOV 


A,D 






0060 


E3 




ORA 


E 






0061 


C 25700 




JNZ 


DNZ 






0064 


060E 




MVI 


B,0EH 






0066 


78 




MOV 


A,E 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 
0067 D333 



0069 
006C 
006F 
0070 
0071 
0072 
0073 
0074 
0075 
0076 
0077 
007A 
007B 
0071' 
007E 
007F 
0080 
0081 
0082 
0083 
0084 
0035 
0086 
0089 
008A 
0081; 
008E 
0090 
0091 



110A01 

210004 

4D 

1A 

13 

Bl 

4F 

2B 

7C 

B5 

C27000 

EE 

1604 

91 

4E 

2B 

7E 

81 

4F 

IB 

7A 

B3 

C27F00 

Bl 

C29300 

7B 

E60I 

47 

r333 



0093 D3ir 
0095 0EFF 
0097 110A01 
009A 21000C 
009D 79 
009E E311 
00 A0 AF 



PROM 
UPC 



DNC 



DMA 



#006 AMC 95/6110 SINGLE DENSITY EDC VI. 3 
OUT R3 JSET NO RAM ERROR 
IPL PROM TEST - UP/DOWN CHECKSUM AND COMPARE 



LXI 

LXI 

MOV 

LDAX 

INX 

ADD 

MOV 

DCX 

MOV 

ORA 

JNZ 

XCHG 

MVI 

SUE 

MOV 

DCX 

MOV 

ADD 

MOV 

DCX 

MOV 

ORA 

JNZ 

ORA 

JNZ 

MOV 

AM 

MOV 

OUT 



OUT 
MVI 
LXI 
LXI 
MOV 
OUT 
XRA 



D,ENTST 

H,1024 

C,I 

D 

D 

C 

C,A 

H 

A,H 

L 

UPC 

E,4 

C 

C,A 

H 

A,M 

C 

C f A 

D 

A,D 

E 

PNC 

C 

DMA 

A f B 

0DE 

E,A 

E3 



{CHECKSUM UPWARDS 



{COMPLEMENT CHECKSUM 
{CHECKSUM DOWNWARDS 



JSET NO PROM ERROR 
IPL DMA TEST - MEMORY/MEMORY TRANSFER 



DMCLR 

C,0FFE 

r.ENTST 

E,RAMAD 

A C 

IM0WC 

A 



{RESET DMA 



{SOURCE WORD COUNT 
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TABLE 3-1. (Cont.) 



AMC MA CEO ASSEM 1.! 



00A1 


E311 


00 A3 


7B 


00A4 


E310 


00A6 


7A 


00A7 


153 IB 


00A9 


79 


0BAA 


D313 


00AG 


AF 


00AE 


E313 


00AF 


B348 


00B1 


7E 


00B2 


E312 


00B4 


7C 


00B5 


B312 


00B7 


3E88 


00B9 


E31B 


00BB 


3E85 


00BE 


E31B 


00BF 


3E41 


00C1 


B318 


00C3 


3E04 


00C5 


E319 


00C7 


0C 


00C8 


BB18 


00CA 


E602 


00CC 


CAE000 


00CI 


1A 


00D0 


BE 


00D1 


C2E000 


00B4 


13 


0BD5 


23 


00E6 


0E 


00E7 


C2CF00 


00EA 


73 


00EB 


E60B 


00BE 


47 


00BE 


B333 


B0E0 


0E0B 


00E2 


113322 


00E5 


BB00 



EML 



#007 AMC 95/6110 SINGLE EENSITY FEC VI. 3 



5SCURCE AEERESS 



OUT 


BM0WC 


MOV 


A,E 


OUT 


BMBAD 


MOV 


A,E 


OUT 


EM BAD 


MOV 


A,C 


OUT 


EM1WC 


XRA 


A 


OUT 


EM1VC 


OUT 


CMESTA 


MOV 


A,L 


OUT 


EM1AE 


MOV 


A,H 


OUT 


EM IAD 


MVI 


A,86H 


OUT 


EMMEE 


MVI 


A,85H 


OUT 


EMMDE 


MVI 


A.41H 


OUT 


EMCST 


MVI 


A, 4 


OUT 


EMREQ 


INR 


C 


IN 


EMCST 


ANI 


2 


JZ 


ENEMA 


LI AX 


r 


CMP 


M 


JNZ 


ENEMA 


INI 


E 


INX 


H 


ECR 


C 


JNZ 


EML 


MOV 


A,B 


ANI 


0BH 


MOV 


B,A 


OUT 


R3 



5EESTINATION WORE COUNT 

JEIRECTION NOT MULTI-EUS 
J DESTINATION AEERESS 

5SOUKCE MOEE 
JBESTINATION MOEE 
5COMMAND 

JEXECUTE REQUEST 



JEOP NOT UP 

I CHECK TRANSFER RESULTS 



ENEMA 



:SET NO EMA ERROR 
IPL FEC TEST - ECHO REGISTERS 

MVI C.ll 

LXI B,2233H 
IN FECST 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 #008 AMC 95/6110 SINGLE DENSITY FDC VI. 3 



00E7 


IF 


00E8 


FA0A01 


00FB 


79 


00EC 


L301 


00EE 


7A 


00EF 


D302 


00E1 


7B 


00F2 


D303 


00F4 


DB01 


00F6 


91 


00F7 


4F 


00F8 


BE 02 


00 FA 


92 


00FB 


El 


00FC 


4F 


00FE 


BB03 


00FF 


93 


0100 


Bl 


0101 


C20A01 


0104 


73 


0105 


E607 


0107 


47 


0108 


B333 


010A 


31200C 


0101 


AF 


010F 


B301 


0110 


E34E 


0112 


21IFFF 


0115 


22010C 


0118 


22030C 


011E 


23 


011C 


2C 


011D 


22050C 


0120 


32130C 


0123 


3C 


0124 


32140C 


0127 


3Ee>e 


0i2e 


32080C 


012C 


07 


012E 


4F 



ENTST 



RAR 

JC 

MOV 

OUT 

MOV 

OUT 

MOV 

OUT 

IN 

SUB 

MOV 

IN 

SUB 

ORA 

MOV 

IN 

SUB 

ORA 

JNZ 

MOV 

ANI 

MOV 

OUT 



FNTST 

A,C 

FDTRK 

A,D 

FBSFC 

A,E 

FBATA 

FDTRK 

C 

C,A 

FDSEC 

E 

C 

C,A 

FBATA 

E 

C 

ENTST 

A,E 

7 

B t A 

R3 



5BUSY 

JSET TRACK REGISTER 
5SET SECTOR REGISTER 
;SET BATA REGISTER 

JCHECK TRACK REGISTER 

J CHECK SECTOR REGISTER 

?CHECK DATA REGISTER 



JSET NO FBC ERROR 

INITIALIZE FORKING STORAGE 

LXI SP, STACK 

XRA A 

OUT FBTRK 5 SET TRACK 

OUT CMBRES J CLEAR COMMAND FF 

LXI H,-l 

SELB POSN J CLEAR UNIT POSITIONS 

SHLD POSN+2 

INX H 

INR L 

SHLE SECTOR 5SECTOR 1, TRACK 

STA INTFLG ; NO INTERRUPT REQUEST 

INR A 

STA SECINC ;i/l INTERLACE 

MVI A, 8 

STA RECNT 5RETRY COUNT-1 

RLC 

MOV C,A 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 
012E 32070C 



0131 3E04 



#009 AMC 95/6110 SINGLE DENSITY EEC VI. 3 



ei33 
0135 
0137 
013A 
013D 
0140 
0143 
0146 
0149 
014C 
014F 
0152 
£153 
0154 
0157 
0158 
0159 



015C 
eiEF 
0160 
0163 
0164 
0167 
0169 
016P 
016E 
2170 
0172 
0173 
0176 
0173 
017A 



E34E 

3E7F 

32000C 

21E102 

220B0C 

211E05 

220E0C 

21C505 

220F0C 

213406 

22110C 

78 

B7 

C26701 

B7 
F26906 



CE9201 

79 

CI 6202 

0F 

31200C 

F680 

E333 

3A130C 

1)348 

EE46 

B7 

F27001 

E34B 

EB33 

5F 



STREQ 



SIESTA 
ILLCOM 
SET COM 



CMDLP 



STA 

IF 

MVI 

STA 

MVI 

ELSE 

MVI 

ENDIF 

OUT 

MVI 

STA 

LXI 

SHLE 

LXI 

SHLE 

LXI 

SHLE 

LXI 

SHLE 

MOV 

ORA 

JNZ 

RIM 

ORA 

JP 



UNIT ;UNIT WITH RETRY 

TYPE EQ 6120 

A,REAE 

IOCOEE JSET NO SIEE COMPARE FOR REAE/WRITE 

A.0CH 

A, 4 

DRSEL SUNIT ZERO, SINGLE IENSITY, SIEE 

A, 127 

SECLEN JSECTOR LENGTH-1 

H.FUNTN 

JPTAB JMISCELLANEOUS FUNCTION JUMP 

F.NBREE 

JPTAB+2 JNON-BUFFEREE REAE JUMP 

H,NBRIT 

JPTAE+4 JNON-BUFFEREE WRITE JUMP 

H,PGMRE 

JPTAB+6 J USER PROGRAM REAE JUMP 

A,B 

A 

SETCOM IGO SET COMPLETE ON IPL ERROR 



A 
BOOT 



5GO BOOT SYSTEM 29 
STATUS RFQUEST C-UNIT 



CALL 

MOV 

CALL 

RRC 

LXI 

ORI 

OUT 

LEA 

OUT 

IN 

ORA 

JP 

OUT 

IN 

MOV 



SELUN 

A,C 

REAEY 

SP, STACK 

60H 

K3 

INTFLG 

CMESTA 

CMESTA 

A 

CMEIP 

CMERES 

R3 

E,A 



JSET UNIT STUFF 



JSET COMPLETE 
JTELL USER 

JSET/CLEAR INTERRUPT 
J CHECK FOR USER COMMANE 



J CLEAR COMMANE FF 
JFETCfl REQUEST 
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TABLE 3-1. (Cont.) 



ANI 


3FH 




MOV 


C,A 


5COUNT-1 


XRA 


E 




RLC 






RLC 






RLC 






MOV 


E,A 




XRA 


A 




MOV 


D,A 




OUT 


BMCLR 


;reset dma 


LXI 


E\JPTAB 




TAD 


r 




MOV 


F,M 


IFETCH VEC 


INX 


B 




MOV 


D,M 




IN 


R0 


J PAGE/UN IT 


XCHG 






PCHL 




;go to jum: 



AMC MACRO ASSEM 1.0 #010 AMC 95/5110 SINGLE DENSITY FDC VI. 3 

217B E63F 
017D 4F 
017E AB 
017F 07 
0180 07 
0131 07 

0182 51 

0183 AF 

0184 57 

0185 B31D 
0187 210B0C 
013A 19 
016B 5E 
018C 23 
01 3D 55 
018E DB30 

0190 EB 

0191 E9 

5 

J SELECT UNIT AND SET VARIABLES C-UMT 

0192 79 SELUN MOV A,C 

0193 32070C STA UNIT 
0196 21070C SETUN LXI H,UNIT 

0199 46 MOV B,M JSAVE PRIOR DRlv* 

019 A 71 MOV M,C 

019E 79 MOV A,C 

019C E608 ANI 8 

019F 17 RAL 

019F 17 RAL 

01A0 17 RAL 

01A1 17 RAL 

01A2 C67F ADI 127 

01A4 32000C STA SECLEN JSECTOR LENGTH-1 

01A7 79 MOV A,C 

01AS E610 ANI 10H 

01AA 0F RRC 

01AB 32080C STA RFCNT 5 RETRY COUNT-1 

01AE 79 MOV A,C 

01AF 07 RLC 

01B0 E601 ANI 1 

01B2 3C INR A 

0153 32140C STA SECINC J INTERLACE 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 



#011 



AMC 95/6110 SINGLE EENSITY FEC VI. 3 



01B6 


79 


01B? 


0F 


01B6 


E620 


01BA 


32130C 


eiBD 


79 


01BE 


11C505 


01C1 


211F05 


01C4 


E620 


01C6 


CAcrei 


01C9 


113704 


01CC 


210703 


01CF 


220E0C 


01E2 


FB 


01D3 


220F0C 


01E6 


79 



01B7 E607 
01E9 EE04 



01EB 
01EE 
01 IT 
01E0 
01E2 
01E5 
01E6 
01E7 
01E9 
01EA 
01EB 
01EE 
01EE 
01EF 
01F1 
01F4 



E34B 

E603 

5F 

1600 

21010C 

19 

7E 

1301 

79 

A3 

E603 

C8 

7E 

1610 

CE8502 

C30004 



SETVEC 



MOV 


A,C 




RKC 






ANI 


20H 




STA 


INTFLG 


5 INTERRUPT REQUEST 


MOV 


A,C 




LXI 


E.NBRIT 




LXI 


H,NEREE 




ANI 


20H 




JZ 


SETVEC 




LXI 


E,BFRIT 




LXI 


H.BFREE 




SHLE 


JPTAB+2 


JSET JUMP TABLE AEDRESS] 


XCEG 






SHLE 


JPTAB+4 




MOV 


A.C 




IF 


TYPE EQ 


6120 


ANI 


0FH 




XRI 


0CH 




ELSE 






ANI 


7 




XRI 


4 




ENDIF 






OUT 


BRSEL 


JSELECT ERIVE 


ANI 


3 




MOV 


E,A 




MVI 


B,0 




LXI 


E.POSN 




DAL 


I 




MOV 


A,M 


JCURRENT UNIT POSITION 


OUT 


FBTRK 


JTELL 1771 


MOV 


A,C 




XRA 


E 




ANI 


T? 




RZ 




5SAMF ERIVE 


MOV 


A,M 




MVI 


E.UNLOE 




CALL 


LOAEA 


JUKLOAE HEAE 


J MP 


POSNC 


JANE POSITION NEW ERIVE 



ROME REQUEST C-UNIT 



01F7 CE1502 HMREO CALL HOME 

IF TYPE FQ 6120 
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AMC MACRO ASSEM 1.0 #012 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



01FA 


E6F9 


01FC 


57 


01FD 


73 


01FE 


32050C 


0201 


7A 


0202 


0F 


0203 


0F 


0204 


E606 


0206 


B2 


0207 


E6L6 


0209 


5F 


020A 


7A 


020B 


E601 


020D 


07 


020E 


07 


020F 


07 


0210 


07 


0211 


B3 


0212 


C 36301 


0215 


CB9201 


0213 


0601 


021A 


AF 


021E 


32060C 


021E 


3 A 030 C 


0221 


0F 


0222 


320A0C 


0225 


CD3E02 


0228 


FB 


0229 


F604 


022B 


7B 


0.22 C 


C0 


022D 


210A0C 


230 


35 


0231 


F22502 


0234 


C9 



PUT ST 1 



HOME 



HOMEL 



INR 


A 




ENDIF 




ANI 


0F9H 


J PUT STATU 


MOV 


I), A 




MOV 


A,B 




STA 


SECTOR 




MOV 


A,B 




RRC 






RRC 






AM 


6 




ORA 


D 




ANI 


0E6E 




MOV 


F,A 




MOV 


A, I) 




ANI 


1 




RLC 






RLC 






RLC 






RLC 






ORA 


E 




JMP 


SIBSTA 




HOME 


FUNCTION C= 


=UNIT 


CALL 


SELUN 




MVI 


B,l 




XRA 


A 




STA 


TRACK 




LM 


RECNT 




RRC 






STA 


SKTRY 




CALL 


RESTORE 




RM 




;not ready 


ANI 


4. 




MOV 


A,E 




RNZ 




;good eome 


LXI 


H, SKTRY 




DCR 


M 




JP 


HOMEL 


JRETRY 


RET 







RESET NON-BUFFERED ADDRESS FALL INTO RESTORE 
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/»MC MACRO ASSEM 1 .2 
0235 2k 222,1 RSNBA 

e?33 ?r 

0239 r-316 
023E 7C 
023C D316 



023E 
0241 
0244 
0245 
0248 
024A 
024B 
024T 
0250 
0251 
0252 
0254 
0257 
0259 
025A 
025C 
025E 
025F 
0260 
0261 



3 A 070 C 

CB6202 

F3 

3A070C 

E603 

5F 

1600 

21010C 

19 

72 

160A 

CD8702 

Eerc 

5F 

DB4B 

E610 

07 

B3 

5F 

C9 



0262 E607 
0264 EE0C 

0266 B34B 
0266 57 
0269 3EB0 
026B D300 
026E E5 



*ei3 AMC 95/5110 SINGLE DENSITY FBC VI. 3 

LHLD BUFF 

MOV A,L 

CUT DM3 AD 

MOV A,H 

OUT DM 3 AD 

EXECUTE RESTOPE 



RESTORE LDA 
CALL 
RM 
LI A 
ANI 
MOV 
MVI 
LXI 
DAD 
MOV 
MVI 
CALL 
ANI 

STSID MOV 
IN 
ANI 
RLC 
ORA 
MOV 
RET 



READY 



READY 



UNIT 
READY 

UNIT 

•7 

E,A 

D.0 

E,POSN 

D 

M,D 

E,RESTR 

ISSUE 

0DCH 

E,A 

CMDSTA 

10H 

E 
E.A 



?NOT READY 



JSET POSTION ZERO 



CHECK READY FOR TYPE I COMMANDS 



IF 

ANI 

XRI 

ELSE 

ANI 

XRI 

ENDIF 

OUT 

MOV 

MVI 

OUT 

PUSH 



TYPE EQ 6120 

0FH 

1CH 

7 
0CE 

LRSEL 
D A 

A^FRCIN 
FDCST 
H 
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AMC MACRO ASSEM 1.0 #014 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



026E 


El 




POP 


E 




0261' 


E5 




PUSH 


H 




0270 


El 




POP 


H 




0271 


DB00 




IN 


FDCST 




0273 


E6C0 




ANI 


0C0H 




0275 


CD5902 




CALL 


STSID 




0273 


7A 




MOV 


A,D 










IF 


TYPE EO 


6120 








ANI 


0FH 










ELSE 






0279 


E607 




ANI 

ENDIF 


7 




027B 


D34B 




OUT 


DRSEL 




027L 


7E 




MOV 


A,E 




027E 


B7 




ORA 


A 




027F 


C9 




RET 










5 


LOAD 1 


iEAD FOR READ/WRITE 


0280 


1616 


LOAD 


MVI 


D,LDHED 




0282 


3A060C 




LLA 


TRACK 




0235 


D303 


LOADA 


OUT 


FDATA 










ISSUE 


COMMAND IN 


D 


0287 


1E00 


ISSUE 


MVI 


E,0 




0289 


ir 


ISSUEA 


DCR 


E 




023A 


CAA902 




JZ 


ISSUEC 


5BUSY 


0281 


DB00 




IN 


FDCST 




028F 


IF 




RAR 






0290 


DA3902 




JC 


ISSUEA 




0293 






SIM 


1BH 


JCLEAR INTERRUPT 


0296 


7A 




MOV 


A,D 




0297 


D300 


ISSUEE 


OUT 


FDCST 


? ISSUE COMMAND 


0299 


FB 




EI 






029A 


11B007 


ISSUED 


LXI 


I), 2000 




0291) 


AF 


ISSUEB 


XRA 


A 




029E 


3D 


ISSUEF 


DCR 


A 




029E 


C29F02 




JNZ 


ISSUEF 


J WAIT FOR INTERR 


02A2 


IB 




DCX 


D 




02A3 


7 A 




MOV 


A,D 




02A4 


B3 




ORA 


E 




02A5 


C29D02 




JNZ 


ISSUEB 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 #015 



AMC 95/6110 SINGLE DENSITY FCC VI. 3 



02A9 F3 




EI 




02A9 78 


ISSUEC 


MOV 


A,B 


02AA 32050C 




STA 


SECTOR 


02AD 3E06 




MVI 


A, 6 


(22AF C 36401 




JMP 


ILLCOM 






SET PARAMETER R 


02B2 DB31 


SETPAR 


IN 


Rl 


02B4 5? 




MOV 


H,A 


02B5 DB32 




IN 


R2 






IF TYPE 


EQ 6120 






MOV 


B,A 






ANI 


7FH 






ENEIF 




02B? 6F 




MOV 


L,A 


22B8 2205eC 




SHLB 


SECTOR 






IF TYPE 


FQ 6120 






MVI 


L,80H 






MOV 


A,B 






ANA 


L 






RLC 








MOV 


E,A 






MOV 


A,C 






ANI 


4 






ORA 


B 






RLC 








ORA 


L 






STA 


IOCOLE 






ENDIF 




02BB CD9601 




CALL 


SETUN 


02BE AF 


BRTN 


XRA 


A 


02BF C36701 




JMP 


SETCOM 






CLEAR INTERRUPT 


02C2 AF 


CLRINT 


XRA 


A 


02C3 47 


NOINT 


MOV 


B,A 


02C4 AF 




XRA 


A 


02C5 D343 




OUT 


CMDSTA 


02C7 78 




MOV 


A,B 


02C8 F680 




ORI 


60H 


02CA D333 




OUT 


R3 



;NC INTERRUPT 



JSTRIP COMPARE FLAG 



5STRIP SITE FLAG 



JSET CONDITIONAL READ/WRITE 
;SET UMT STUFF 



JCLEAR INTERRUPT 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 
02CC C37001 



02CF 3A070C 
0212 C3C302 



02D5 3A060C 
02re C3C302 



02DB 3A050C 
02DE C3C302 



02E1 
02E2 
02E3 
02E4 
02E6 
02E3 
02EB 
02 ED 
02E0 
02F1 
02E2 
02F3 
02F4 
02E5 
02F6 
02F? 
02F9 
02FB 
02FD 
02FE 
0301 
0303 
0305 



59 

4F 

7B 

FE06 

3E05 

D26701 

1600 

21F702 

19 

19 

5E 

23 

56 

FB 

E9 

F701 

B202 

5C01 

C202 

CE06 

CF02 

D502 

DE02 



I NT UN T 



INTTRK 



I NT SEC 



FUNTN 



VECTAB 



#016 AMC 95/6110 SINGLE DENSITY FDC VI. 3 
JMP CMDLP 
RETURN UNIT REQUEST 



LDA 
JMP 



UNIT 
NOINT 



RETURN TRACK REQUEST 



LDA 
JMP 



TRACK 
NOINT 



RETURN SECTOR REQUEST 



LEA 
JMP 



SECTOR 
NOINT 



REQUEST CODES 0-63 



MOV 

MOV 

MOV 

CPI 

MVI 

JNC 

MVI 

LXI 

DAD 

DAD 

MOV 

INX 

MOV 

XCEG 

PCHL 

DV 

DW 

DW 

DW 

DW 

DW 

DW 

DW 



ILLEGAL FUNCTION 



E,C 

C f A 

A f E 

8 

A 5 

SETCOM 

D ,0 

H,'vECTAB 

D 

D 

E,M 

H 

T,M 



HMREQ JHOME REQUEST 

SETPAR 5SET I/O PARAMETERS 

STREQ 5STATUS REQUEST 

CLRINT J CLEAR INTERRUPT REQUEST 

INIDSK J INITIALIZE DISK REQUEST 

INTUNT ; INTERROGATE UNIT 

INTTRK INTERROGATE TRACK 

INTSEC INTERROGATE SECTOR 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 #017 



AMC 95/6110 SINGLE TENSITY FDC VI. 3 



MULTIPLE SECTOR BUFFERED READ A=PAGE 



0307 
0309 
030B 
0301 
030F 
0311 
0313 
0315 
0317 
0319 
031A 
031D 
031F 
0321 
0323 
0325 
0328 
329 
032B 
032C 
032E 
032F 
0331 
0332 
0334 
0335 
0337 
0339 
033E 
033B 
033F 
0341 
0344 
0345 
0348 
034E 
034C 
034F 
034F 
0351 
0353 



B34A 

3F00 

B310 

3E0F 

L310 

DB32 

1)312 

BB31 

D312 

AF 

32092C 

3E00 

D316 

3E0F 

D316 

3A000C 

6F 

D311 

AF 

D311 

?B 

D31? 

AF 

1)317 

57 

3F98 

D31B 

3E65 

B31B 

3E57 

1)3 IB 

3A050C 

47 

CEEF03 

FAFA01 

AF 

L346 

7S 

D302 

3ED0 

B300 



BFRED 



BFREDR 



EFREDL 



BFREDS 



OUT 


SEGMT 


JSET PAGE 




MVI 


A.BUFF- 


■BUFF/256*256 




OUT 


DM0AD 


?M/M SOURCE ADDRESS 




MVI 


A, BUFF/256 




OUT 


BM0AD 






IN 


R2 






CUT 


DM IAD 


JM/M DESTINATION ADDRESS 




IN 


Rl 






OUT 


LM1AD 






XRA 


A 






STA 


RETRY 


5SET READ RETRY 




MVI 


A,EUFF- 


-BUFF/256*256 




OUT 


DM3AD 


J INPUT ADDRESS 




MVI 


A.BUFF/256 




OUT 


BM3AD 






LBA 


SECLEN 






MOV 


L,A 






CUT 


DM0 WC 


JM/M SOURCE WORD COUNT 




XRA 


A 






OUT 


DM0 WC 






MOV 


A,L 






OUT 


DM3 WC 


J INPUT WORD COUNT 




XRA 


A 






OUT 


DM3 WC 






MOV 


B,A 






MVI 


A,98H 






OUT 


DMMDE 


IM/M SOURCE MODE 




MVI 


A.65H 






OUT 


DMMDE 


JM/M DESTINATION MODE 




MVI 


A.57H 






OUT 


DMMDE 


J INPUT MOLE 




LDA 


SECTOR 






MOV 


B,A 






CALL 


POSITN 


JREAD LOOP B=SECTOR. C=COUNT, 


(HL)^POSITION 


JM 


PUTST1 






XRA 


A 






OUT 


CMDSTA 


J INPUT TO LOCAL BUFFER 




MOV 


A,B 






OUT 


FDSEC 


JDESIRED SECTOR 




MVI 


A,FRCIN 




OUT 


FDCST 


5 REQUEST STATUS I 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 #018 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



0355 3E40 
0357 D318 

0359 3E07 
035B B31F 
035L 

0360 DB00 
036 2 E620 
0364 CC8002 



0367 3F88 



0369 
036C 
036E 
0371 
0374 
375 
0377 
0379 
£37C 
037L 
0380 
0381 
0382 
0385 
0338 
038B 

038 C 
033D 
038E 
0391 

039 2 
0394 
0395 
0396 
0397 
0398 
39 A 
039B 
0391 
39E 



CB9702 

E69C 

CAA203 

EA8C03 

57 

3E£F 

D31F 

21090C 

34 

3 A 080 C 

BF 

7A 

FA8C03 

CB3E02 

C31D03 

AF 

57 

73 

32050C 

7A 

E620 

0F 

0F 

0F 

B2 

E6DC 

57 

F61C 

B2 

0F 



PUTST3 
PUTST2 



MVI 

OUT 

MVI 

OUT 

SIM 

IN 

ANI 

cz 

IF TYPE 

LDA 

ELSE 

MVI 

ENDIF 

CALL 

ANI 

JZ 

JM 

MOV 

MVI 

OUT 

LXI 

INR 

LDA 

CMP 

MOV 

JM 

CALL 

JMP 

XRA 

MOV 

MOV 

STA 

MOV 

ANI 

REC 

RRC 

RRC 

CRA 

AM 

MOV 

ANI 

ADD 

RRC 



A,40H 

BMCST 

A 7 

DMMSK 

1BH 

FICST 

20E 

LOAL 

FQ 6120 

ICCODE 

A, REAL 

ISSUEF 

RLMSK 

BFREDG- 

PUTST2 

L,A 

A,0FH 

DMMSK 

H, RETRY 

M 

EECNT 

M 

A,D 

PUTS T 2 

RESTORE 

EFREDR 

A 

L,A 

A,B 

SECTOR 

A,D 

20H 



r 

0DCE 

D,A 

1CH 

d 



JCOMMANT DMA 

; ENABLE CHANNEL 3 

5 HEAD LOAD STATUS 



5 EXECUTE REAL 

;GOOL READ 
J-NOT READY 



;DISABLE CHANNEL 3 



;end retry 



JSAVE SECTOR/SET READ-tfRITF STATUS 
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AMC MACRO ASSEM 1.0 #019 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



039F 


C 36701 


03A2 


32090C 


03A5 


2F 


03A6 


D31F 


03A8 


3A000C 


03AB 


D313 


03AD 


AF 


03AE 


D313 


0310 


3E41 


03B2 


D318 


03B4 


3E04 


03E6 


D348 


3B9 


D319 


03BA 


DB18 


C?3BC 


E602 


03BE 


CABA03 


03C1 


3A140C 


03C4 


90 


03C5 


47 


e3C6 


D61E 


03C8 


DAE103 


03CE 


C2D103 


03CE 


3A140C 


03B1 


47 


£3D2 


3D 


03r3 


C2E103 


03D6 


21060C 


3D9 


7E 


03 DA 


3C 


03DB 


FE4D 


03DD 


CA8B03 


03E0 


77 


03E1 


0L 


03E2 


FA8B03 


03E5 


3E01 


03E7 


90 


03E8 


C24B03 


03EB 


57 


03EC 


C34503 


C3EF 


3A070C 



BFfcEIG 



EFREDW 



BFREIA 



BFREDD 



JMP 

STA 

CMA 

OUT 

IDA 

OUT 

XRA 

OUT 

MVI 

OUT 

MVI 

OUT 

OUT 

IN 

ANI 

JZ 

IDA 

ADD 

MOV 

SUI 

JC 

JNZ 

LDA 

MOV 

DCR 

JNZ 

LXI 

MOV 

INR 

CPI 

JZ 

MOV 

ECR 

JM 

MVI 

SUB 

JNZ 

MOV 

JMP 



SETCOM 
RETRY 

DMMSK 

SECLEN 

EM1WC 

A 

IM1WC 

A,41H 

DMCST 

A. 4 

CMDSTA 

DMREO 

DMCST 

c 

BFREDW 

SECINC 

B 

B,A 

27 

EFREDD 

BFREDA 

SECINC 

B,A 

A 

BFREDD 

E, TRACK 

A,M 

A 

77 

PUTST3 

M, A 

C 

PUTST3 

A,l 

E 

BFREDS 

D,A 

EFRFDL 



JRESET RETRY 

JDI5ABLE CHANNEL 3 

5M/M DESTINATION WORD COUNT 

5COMMAND DMA 

J LOCAL BUFFER TO HOST 
5REQUEST DMA 
JWAIT DMA TRANSFER 

5 ADVANCE SECTOR 



;NOT END TRACK 

;END 2/1 INTERLACE TRACK 



jend 2/1 interlace half track 

j advance track 

;disk overflow 

5 check sector count 
?end request 



JSAME TRACK 

JDIFFERENT TRACK 

J RE-POSITION TRACK 

» 

POSITN LDA UNIT 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 #020 



AMC 95/6110 SINGLE DENSITY FBC VI. 3 



03F2 


E603 




ANI 


3 




03F4 


5F 




MOV 


E,A 




0315 


1600 




MVI 


D,0 




03F7 


21010C 




LXI 


H,POSN 




03FA 


19 




DAD 


D 




03FB 


3A060C 




IDA 


TRACK 




03FE 


BE 




CMP 


M 




03FF 


C8 




RZ 






0400 


3A080C 


POSNC 


LDA 


RFCNT 




040 3 


0F 




RRC 






0404 


320A0C 




STA 


SKTRY 


5EETRY COUNT 


0407 


7E 


POSNA 


MOV 


A,M 




0408 


B7 




ORA 


A 




0409 


FA2C04 




JM 


POSND 


J INITIAL REFERENCE - RES 


040 C 


3A070C 




LDA 


UNIT 




040F 


CD6202 




CALL 


READY 




0412 


F8 




RM 






0413 


3A060C 




LDA 


TRACK 




0416 


D303 




OUT 


FDATA 




0418 


77 




MOV 


M.A 


5UPDATE POSITION 


0419 


161E 




MVI 


D,SEEK 




041B 


CD3702 




CALL 


ISSUE 




041E 


E698 




ANI 


98H 




0420 


C8 




RZ 




JGOOD SEEK 


0421 


F3 




RM 




J NOT READY 


0422 


5F 




MOV 


E,A 




042? 


3A0A0C 


POSNB 


LDA 


SKTRY 




0426 


3D 




DCR 


A 




0427 


320A0C 




STA 


SKTRY 




042 A 


7E 




MOV 


A,E 




042E 


F3 




RM 




;end RETRY 


042C 


CD3E02 


PCSND 


CALL 


RESTORE 




042F 


E604 




ANI 


4 




0431 


C20704 




JNZ 


POSNA 




0434 


C32304 




JMP 


POSNB 










MULTIPLE SECTOR 


BUFFERED WRITE A=?AGF 


0437 


D34A 


BFRIT 


OUT 


SEGMT 


JSET PAGE 


0439 


3E00 




MVI 


A, BUFF- 


BUFF/256*256 


043B 


D312 




OUT 


DM1AD 


JM/M DESTINATION ADDRESS 


043D 


3E0F 




MVI 


A, BUFF/ 


256 


043F 


D312 




OUT 


DM1AD 
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AMC MACRO ASS-EM 1.0 #021 



AMC 95/6110 SINGLE TENSITY FDC 71. 3 



441 


LB32 


0443 


13 10 


2445 


LB31 


447 


D310 


244.9 


3E00 


044E 


D316 


0441' 


3E£F 


044F 


D316 


£451 


3A000C 


£454 


6F 


0455 


D313 


0457 


AF 


£453 


D313 


045 A 


71 


045E 


D317 


045D 


AF 


04 5 E 


D317 


0460 


57 


0461 


3538 


0463 


L31B 


0465 


3E95 


0467 


D31B 


0469 


3E5E 


046B 


D31B 


£46L 


3A050C 


0470 


47 


0471 


CDEF03 


0474 


FAFA01 


0477 


3A000C 


047A 


D311 


047C 


AF 


047D 


32090C 


0480 


L311 


£432 


3E41 


0484 


D318 


0486 


3L06 


£488 


D34S 


04.8 A 


3E04 


048C 


D319 


£43E 


DB18 


0490 


E602 


0492 


CA8F04 


0495 


AF 



EFRITL 



BFRITS 



EFRITW 



BFRITR 



IN 


R2 






OUT 


TM0AL 


5M/M SOURCE ATLRESS 




IN 


Rl 






OUT 


LM0AD 






MVI 


A.BUFF- 


-BUFF/256*256 




OUT 


LM3AD 


J OUTPUT ALLRESS 




MVI 


A, BUFF/256 




OUT 


LM3AD 






LM 


SECLEN 






MOV 


L ,A 






OUT 


LM1WC 


;m/m destination mrd count 




XRA 


A 






OUT 


DM1WC 






MOV 


A.L 






OUT 


DM3WC 


; OUTPUT word count 




XRA 


A 






OUT 


LM3WC 






MOV 


D,A 






MVI 


A.33H 






CUT 


LMMDE 


JM/M SOURCE MOLE 




MVI 


A,95H 






OUT 


LMMDE 


:M/M DESTINATION MODE 




MVI 


A.5BH 






OUT 


LMMLE 


J OUTPUT MODE 




LM 


SECTOR 






MOV 


B.A 






CALL 


POSITN 


JWRITE LOO? E=SECTOR, C=CCUNT t 


(HL)=POSITION 


JM 


PUTST1 






LDA 


SECLEN 






OUT 


DM0WC 


JM/M SOURCE WORD COUNT 




XRA 


A 






STA 


RETRY 


JSET RETRY COUNT 




OUT 


EM0WC 






MVI 


A,41H 






OUT 


LMCST 


J COMMAND DMA 




MVI 


A, 6 






OUT 


CMDSTA 


;HOST TO LOCAL BUFFER 




MVI 


A, 4 






OUT 


EMREQ 


JREQUEST DMA 




IN 


LMCST 


5WAIT DMA TRANSFER 




ANI 


2 






JZ 


EFRITW 






XRA 


A 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 



#022 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



0496 


D343 


0498 


78 


0499 


D302 


049B 


3ED0 


0491' 


D300 


049F 


3F.40 


04A1 


D318 


04A3 


3E07 


04A5 


B31F 


04A? 




04AA 


DB00 


04AC 


E620 


04AE 


CC8002 



04B1 


3EA8 


04B3 


CB9702 


04B6 


E6IC 


04B3 


CAEE04 


04BB 


57 


04BC 


E6C0 


04BE 


7A 


04BF 


C28C03 


04C2 


3F0F 


04C4 


L31F 


04C6 


21090C 


04C9 


34 


04CA 


3A030C 


04CB 


BE 


04 CE 


7A 


04CF 


FA8C03 


04B2 


CB3E02 


04E5 


CBEF03 


04B3 


FAFA01 


04DB 


3E00 


04BD 


D316 


04BF 


3E0F 


04E1 


B316 


04F3 


3A000C 


04E6 


D317 



OUT 


CMBSTA 


; OUTPUT FROM LOCAL BUFFER 


MOV 


A,B 




OUT 


FDSEC 


J DESIRED SECTOR 


MVI 


A.FRCIN 




OUT 


FBCST 


JREQUEST STATUS I 


MVI 


A.40H 




OUT 


BMCST 


; COMMAND DMA 


MVI 


A, 7 




OUT 


BMMSK 


;EKAELF CHANNEL 3 


SIM 


IBB 




IN 


FECST 


;eead LOAD STATUS 


AM 


20H 




CZ 


LOAB 




IF TYPE 


EQ 6120 




LI)A 


IOCOBE 




OR I 


20H 




ELSE 






MVI 


A, WRITE 




ENDIF 






CALL 


ISSUEE 


JFXECUTE WRITE 


AM 


WRMSK 




JZ 


BFRITG 


;good write 


MOV 


D,A 




AM 


0C0H 




MOV 


A,D 




JNZ 


PUTST2 


;not eeady or write prote 


MVI 


A,0FH 




OUT 


BMMSK 


JDISABLE CHANNEL 3 


LXI 


H, RETRY 




INR 


M 




LDA 


RECNT 




CMP 


M 




MOV 


A,D 




JM 


PUTST2 


;end retry 


CALL 


RESTORE 




CALL 


POSITS 




JM 


PUTST1 




MVI 


A ,BUFF-BUFF/256*256 


OUT 


BM3AB 


J RESET OUTPUT ADDRESS 


MVI 


A, BUFF/256 


OUT 


PM3AD 




LB A 


SECLEN 




OUT 


BM3WC 


JRESET OUTPUT WORD COUNT 
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AMC MACRO ASSEM 1.0 #023 



EFRITG 



04E3 


AF 


04E9 


D317 


04FB 


C39504 


04EE 


2F 


04EF 


D31F 


04F1 


3A 140C 


04F4 


80 


04F5 


47 


04F6 


L61B 


04F3 


BA1105 


04FE 


C20105 


04FE 


3A140C 


501 


47 


0502 


3D 


0503 


C21105 


0506 


21060C 


0509 


7E 


050 A 


3C 


050B 


FE4D 


050B 


CA3B03 


0510 


77 


0511 


0D 


0512 


FA3B03 


0515 


3E.01 


0517 


90 


0513 


C27704 


051B 


57 


51C 


C 37 104 


051F 


B34A 


0521 


BE 32 


523 


D316 


0525 


DB31 


0527 


D316 


2 529 


3F47 


052B 


D31B 


052D 


3E02 


0521 


B348 


0531 


3E40 


0533 


E318 


0535 


3A050C 



BFRITA 



BFRITB 



NBREI) 



NBREBB 



AMC 95/6110 SINGLE BENSITY FBC VI. 3 



JDISABLE CHANNEL 
5ADVANCE SECTOR 



XRA 


A 


OUT 


BM3tfC 


JMP 


BFRITR 


CMA 




OUT 


EMMSK 


LDA 


SECINC 


ABB 


B 


MOV 


B,A 


SUI 


27 


JC 


BFRITB 


JNZ 


BFRITA 


LBA 


SECINC 


MOV 


B,A 


BCR 


A 


JNZ 


BFRITB 


LXI 


F, TRACK 


MOV 


A,M 


INR 


A 


CPI 


77 


JZ 


PUTST3 


MOV 


M,A 


BCR 


C 


JM 


PUTST3 


MVI 


A,l 


SUE 


B 


JNZ 


BFRITS 


MOV 


B,A 


JMP 


BFRITL 


MULTIPLE SECTOR 


OUT 


SEGMT 


IN 


R2 


OUT 


BM3AB 


IN 


Rl 


OUT 


BM3AB 


MVI 


A,47H 


OUT 


BMMBE 


MVI 


A f 2 


OUT 


CMBSTA 


MVI 


A,40H 


OUT 


BMC ST 


LBA 


SECTOR 



JNOT ENB TRACK 

;ENB 2/1 INTERLACE TRACK 



jene 2/1 interlace half track 

jadvance track 

;bisk overflow 

jcheck sector count 
;end request 

5same track 
different track 
non-buffereb real a=pase 
jset page 
j input address 

5 input mode 
5 input to host 
; command dma 
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*MC MACRO ASSEM 1.0 #024 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



0538 
0539 
053A 
053D 
540 
0543 
546 
548 
0549 
54B 
54D 
054$ 
0550 
0551 
0554 
0555 
0557 
0559 
055B 
055E 
055F 
562 
0564 
e566 



47 

AF 

320S0O 

CDEF03 

FAFA01 

3A000C 

D317 

AF 

D31? 

DE16 

6F 

DB16 

67 

220001 

78 

D302 

3ED0 

D300 

3E07 

D31I 

DB00 

E620 
CC8002 



0569 


3E33 


0561 


CD9702 


056E 


E69C 


0570 


C A 81 05 


0573 


IA8C03 


576 


57 


0577 


3E2F 


0579 


13 IF 


057E 


21090C 


057E 


34 


57F 


3A080C 


0532 


BE 


0583 


7 A 


0584 


FA8C03 


£5 3? 


CD3502 



NBREDR 



NBREDL 



N BR EDS 



MOV 

XRA 

STA 

CALL 

JM 

LDA 

OUT 

XRA 

OUT 

IN 

MOV 

IN 

MOV 

SHLD 

MOV 

OUT 

MVI 

OUT 

MVI 

CUT 

SIM 

IN 

ANI 

CZ 

IF TYPE 

LDA 

ELSE 

MVI 

ENDIF 

CALL 

ANI 

JZ 

JM 

MOV 

MVI 

OUT 

LXI 

INR 

LDA 

CMP 

MOV 

JM 

CALL 



B,A 

A 

RETRY 

POSITN 

PUTST1 

SFCLEN 

DM3WC 

A 

DM3WC 

DM3AD 

L,A 

PM3AD 

H,A 

BUFF 

A f B 

FDSEC 

A,FRCIN 

FDCST 

A. 7 

IMMSK 

1BH 

FDCST 

20H 

LOAI 

EO 6120 

ICCODE 

A, READ 

ISSUEE 

RDMSK 

NBREDG 

PUTST2 

B,A 

A.0FH 

IMMSK 

H, RETRY 

M 

RECNT 

M 

A,D 

PUTST2 

RSNBA 



JSET READ RETRY 



? INPUT WORD COUNT 



JSAVE ADRESS FOR RETRY 
JDESIRED SECTOR 
?REQUEST STATUS I 
JENABLE CHANNEL 3 
?HEAD LOAD STATUS 



? execute read 

;good read 
5 not ready 



JDISAELF CHANNEL 3 



5END RETRY 
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AMC MACRO ASSEM l.i 



53 A 


C33B05 


0581 


32090C 


2590 


2F 


0591 


D31F 


0593 


3A140C 


596 


80 


0597 


47 


0598 


D61B 


059A 


DAB305 


059D 


C2A305 


05A0 


3A140C 


05A3 


47 


5A4 


3D 


05A5 


C2B305 


05A8 


21060C 


05AE 


7E 


05AC 


3C 


05 AD 


FF4L 


0?AF 


CA8I03 


05B2 


77 


0£B3 


0L 


05B4 


79 


05B5 


3C 


05B6 


CA8B03 


5B9 


FA7506 


05BC 


3E01 


05BE 


90 


05BF 


C25405 


05C2 


C33B05 


05C5 


D34A 


5C7 


DB32 


05C9 


I>316 


05CB 


LE31 


0?CP 


D316 


05CF 


3F4E 


511 


D31B 


2 5B3 


3S02 


051)5 


D348 


05B7 


3F40 


5D9 


D313 



NBREDG 



NBhEDA 



NBREBI' 



NBRIT 



#025 AMC 95/6110 SINGLE TENSITY FBC VI. 3 

5 RESET RETRY COUNT 
JDISABLE CHANNEL 3 
5ADVANCE SECTOR 



5 NOT END TRACK 

JEND 2/1 INTERLACE TRAC] 



JMP 


NBREDR 


STA 


RETRY 


CMA 




OUT 


DMMSK 


LDA 


SECINC 


ALE 


B 


MOV 


B f A 


SUI 


27 


JC 


NEREDE 


JNZ 


N BREDA 


LLA 


SECINC 


MOV 


B,A 


DCR 


A 


JNZ 


NBREDD 


LXI 


F, TRACK 


MOV 


A,M 


INR 


A 


CPI 


77 


JZ 


PUTST3 


MOV 


M,A 


DCR 


C 


MOV 


A t C 


INR 


A 


JZ 


PUTST3 


JM 


EOOTA 


MVI 


A.l 


SUB 


B 


JNZ 


NBREDS 


JMP 


NBREDR 


MULTIPLF SECTOR 


CUT 


SEGMT 


IN 


R2 


OUT 


DM3AD 


IN 


Rl 


OUT 


DM3AD 


MVI 


A.4BE 


OUT 


EMMDE 


MVI 


A, 2 


OUT 


CMDSTA 


MVI 


A,40E 


OUT 


DMCST 



jend 2/1 interlace half track 

jaivance track 
;disk overflow 
; check sector count 



JFND REQUEST 
5SYSTEM 29 BOOT EXIT 



JSAME TRACK 
DIFFERENT TRACK 

NON-BUFFERED WRITE A=PAGE 

?SET PAGE 

JOUTPUT ADDRES 

JOUTPUT MODE 
JOUTPUT FROM HOST 
JCOMMAND DMA 
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AMC MACRO ASSEM 1 



05 LB 


3A050C 


05EE 


47 


05BF 


AF 


05E0 


32090C 


05E3 


CEEE03 


05E6 


FAFA01 


05E9 


3A000C 


0EEC 


E317 


0EEE 


AF 


05EF 


1-317 


05E1 


DB16 


05F3 


6F 


05F4 


IB16 


05F6 


67 


5F7 


22000F 


05FA 


78 


05FE 


E302 


05FB 


3ED0 


5FE 


E3 00 


0601 


3E07 


0603 


D31F 


0605 




0608 


EB00 


060 A 


E620 


060C 


CC8002 



060F 


3EA8 


0611 


CE9702 


614 


E6FC 


0616 


CA3606 


061? 


57 


061A 


E6C0 


061 C 


7A 


061F 


C28C03 


0620 


3E0F 


0622 


E31F 


0624 


21090C 


0627 


34 


0628 


3A080C 



NBRITR 



NBRITL 



NBRITS 



#026 

LEA 

MOV 

XRA 

STA 

CALL 

JM 

LEA 

OUT 

XRA 

OUT 

IN 

MOV 

IN 

MOV 

SHLE 

MOV 

OUT 

MVI 

OUT 

MVI 

OUT 

SIM 

IN 

ANI 

CZ 

IF TYPE 

LEA 

ORI 

FLSE 

MVI 

ENEIF 

CALL 

ANI 

JZ 

MOV 

ANI 

MOV 

JNZ 

MVI 

OUT 

LXI 

INR 

LEA 



AMC 95/6110 SINGLE EENSITY FEC VI. 3 



SECTOR 

B,A 

A 

RETRY 

POSITN 

PUTST1 

SECLEN 

EM3WC 

A 

EM3WC 

EM3AE 

L,A 

EM3AE 

E,A 

BUFF 

A,B 

FESEC 

A.FRCIN 

FECST 

A 7 

EMMSK 

1BH 

FECST 

20H 

LOAE 

FQ 6120 

IOCOEE 

20H 

A, WRITE 

ISSUEE 

WEMSK 

NBRITG 

E,A 

0C0H 

A,B 

PUTST2 

A,0FH 

EMMSK 

B, RETRY 

M 

EEC NT 



5SET WRITE RETRY 



JOUTPUT WORE COUNT 



;SAVE AEERESS FOR RETRY 
5EESIREE SECTOR 
J REQUEST STATUS I 
JENABLE CHANNEL 3 
JHEAE LOAE STATUS 



5 EXECUTE WRITE 



;gooe write 



;not reaey or write protect 
jbisable channel 3 
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AMC MACRO ASSEM 1.0 



#027 



AMC 95/6110 SINGLF TENSITY FEC VI. 3 



062E 


BE 




CM? 


M 




£62C 


7A 




MCV 


A,D 




0621 


EASC03 




J M 


PUTST2 


JENE RETRY 


630 


CE2502 




CALL 


RSNBA 




0633 


C3E305 




JMP 


NBRITR 




0636 


32090C 


NBRITG 


STA 


RETRY 


JRESET RETRY 


0639 


2E 




CMA 






063 A 


E31F 




OUT 


EMMSK 


;EI5ABLE CHANNEL 3 


063C 


3A140C 




LEA 


SECINC 




'263F 


B.0 




AEE 


B 


JAEVANCE SECTOR 


0640 


47 




MOV 


B,A 




0641 


re ib 




SUI 


27 




0643 


EA5C06 




JC 


NERITE 


JNOT ENE TRACK 


0646 


C24C06 




JNZ 


NBRITA 


JEND 2/1 INTERLACE ' 


0649 


3A140C 




LEA 


SECINC 




064C 


47 


NERITA 


MOV 


E,A 




064D 


3D 




BCR 


A 




?64i 


C25C06 




JNZ 


NBRITB 


JENE 2/1 INTERLACE 


0651 


21060C 




LXI 


R, TRACK 




0654 


7E 




MOV 


A,M 




0655 


3C 




INR 


A 


JAEVANCE TRACK 


0656 


FE4B 




CPI 


77 




06E3 


CA3E03 




JZ 


PUTST3 


;eisk overflow 


065B 


77 




MOV 


M,A 




065C 


0E 


NERITE 


ECR 


C 


5 CHECK SECTOR COUNT 


G65D 


FA3B03 




JM 


PUTST3 


JEND REQUEST 


0660 


3E01 




MVI 


A,l 




0662 


90 




SUB 


B 




0663 


C2FA05 




JNZ 


NBRITS 


JSAME TRACK 


0666 


C3E305 




JMP 


NBRITR 


JEIFFERENT TRACK 






> 


SPECIAL 


AUTO-BOOT FOR SYSTFM 29 


2669 


0EFF 


BOOT 


MVI 


C0FFH 


JBOOT FLAG 


066B 


AF 




XRA 


A 




066C 


E34A 




OUT 


SEGMT 


J SET PAGE 


066E 


13 IE 




OUT 


EMCLR 


J RESET DMA 


0670 


D316 




OUT 


EM3AD 


J INPUT AEERESS 


0672 


C 3 2705 




JMP 


NBREEB 


J GO EO IT 


0675 


7S 


BOOTA 


MOV 


A,B 




£676 


32050C 




STA 


SECTOR 




0679 


E349 




OUT 


RESET 


J RETURNS HERE IF BO 


067E 


B34E 




OUT 


RELSE 


JRELEASF CPU 
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AMC MACRO ASSEM 1.0 



#028 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



067D 


3F20. 


067 F 


D34S 


2681 


C3BE02 


0634 


D34A P 


0686 


3E06 


0688 


D348 


063A 


D31D 


068 C 


3E88 


068E 


D31B 


0690 


BB32 


0692 


D310 


0694 


DE31 


0696 


1)310 


0696 


21200C 


069B 


7D 


069C 


D312 


0691 


7C 


069i 


D312 


06A1 


3E85 


06A3 


13 IB 


06A5 


79 


06A6 


3C 


06A7 


6F 


06A8 


2600 


06AA 


29 


06AB 


29 


06AC 


2£ 


06AD 


29 


06AE 


29 


06AF 


29 


06B0 


7D 


06B1 


D311 


06B3 


7C 


06B4 


B311 


06B6 


71 


06B7 


L313 


06B9 


7C 


06BA 


D313 


06BC 


3F41 


06EE 


D313 



PGMRD 



MVI 


A f 20H 




OUT 


CMDSTA 


5PULSE INTERRUPT 


JMP 


BRTN 




USER 


PROGRAM LOAD AND EXECUTE 


OUT 


SEGMT 


;SET PAGE 


MVI 


A, 6 




OUT 


CMDSTA 


5 HOST TO LOCAL MEMORY 


OUT 


DMCLR 


JRESET DMA 


MVI 


A.88H 




OUT 


DMMDF 


JSOURCE MODE 


IN 


R2 




OUT 


DM0AD 


JSOURCE ADDRESS 


IN 


Rl 




OUT 


DM0AD 




LXI 


H, PGM AD 




MOV 


A,L 




OUT 


DM1AD 


DESTINATION ADDRESS 


MOV 


A.H 




OUT 


DM IAD 




MVI 


A.35H 




OUT 


DMMDE 


DESTINATION MODE 


MOV 


A,C 




INR 


A 




MOV 


L,A 




MVI 


E,0 




DAD 


H 


5VALUE TIMES 64 


DAD 


H 




DAD 


E 




DAD 


H 




DAD 


H 




DAD 


H 




MOV 


A,L 




OUT 


DM0WC 


JSOURCE fc'ORD COUNT 


MOV 


A,E 




OUT 


DM0WC 




MOV 


A,L 




OUT 


DM1 WC 


J DESTINATION WORD COU 


MOV 


A,H 




OUT 


DMltfC 




MVI 


A f 41E 




OUT 


DMCST 


; COMMAND DMA 
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WC MACRO ASSEM 1.0 #029 



AhC 95/6110 SINGLE DENSITY FEC VI. 3 



eece 3E&4 
eecz r'3ie 

06C4 BB18 
06C6 E602 
06C8 CAC406 
06CE C3200C 



06CE CD 1502 
061)1 3A050C 
0bD4 47 
06E5 7B 
26B6 F604 
06ES 7E 
061)9 CAFA01 
06EC AE 
06DD D348 



PGMRPW 



06DI 


21AC07 


06E2 


11200C 


06E5 


CE9C07 


?6E6 


3A060C 


06FB 


32700C 


06EE 


79 


06EE 


E604 


06F1 


0F 


06E2 


0E 


06F3 


32710C 


06F6 


T31B 


06F8 


21200C 


06EB 


7D 


06FC 


B314 


06FE 


7C 



INIBSK 



INIADV 



MVI 


A, 4 




OUT 


DMREQ 


JREQUEST LMA 


IN 


EMCST 


5 WAIT DMA TRANSFER 


ANI 


2 




JZ 


PGMRDtf 




JMP 


PGMAD 


JGO TO USER PROGRAM 


INITIALIZE riSK 


- SINGLE DENSITY 


CALL 


HOME 




LBA 


SECTOR 




MOV 


B,A 




MOV 


A,E 




ANI 


4 




MOV 


A,E 




JZ 


PUTST1 


J HOME ERROR 


XHA 


A 




OUT 


CMDSTA 


jdirection 


IF 


TYPE EQ i 


6120 


MOV 


A,C 




ANI 


0CH 




XRI 


0CH 




JZ 


BINADV 


JDOUBLE AND SIDE 2 


MOV 


A,C 




ANI 


7 




XRI 


ecu 




OUT 


DRSEL 


5FORCE SINGLE DENSITY 


ENBIF 






LXI 


H, INI TAB 




LXI 


D, PGMAD 




CALL 


INIFIL 


5FORM TRACK MASK 


LEA 


TRACK 




STA 


PGMAB+30 




MOV 


A.C 




ANI 


4 




RRC 






RRC 






STA 


PGMAE+81 


JSET SIDE 


OUT 


EMCLR 


JRESET DMA 


LXI 


H, PGMAD 




MOV 


A f L 




OUT 


DM2AD 


;track header address 


MOV 


A,H 
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AMC MACRO ASSEM 1.0 



#030 



AMC 95/6110 SINGLE DENSITY FDC VI. 3 



06FF 


D314 


0701 


3F48 


0703 


1315 


0705 


AF 


0706 


E315 


0708 


3E4A 


070A 


D31E 


070C 


21690C 


070F 


7B 


0710 


D316 


0712 


7C 


0713 


B316 


0715 


3EB9 


0717 


D317 


0719 


AF 


071A 


D317 


071C 


3E5B 


071E 


I31E 


0720 


3F40 


0722 


D31S 


0724 


3E03 


0726 


B31F 


0723 




072B 


3EJ4 


0721 


E300 


072F 


216D07 


0732 


E5 


0733 


FB 


0734 


DB17 


0736 


desd 


0738 


LB17 


073A 


F23407 


073D 


21720C 


0740 


34 


0741 


7E 


0742 


FE1E 


0744 


CA5107 


0747 


DB13 


0749 


E508 


074E 


CA4707 


074E 


C33407 


0751 


21CA07 


0754 


116S0C 



WAITC 



WAITS 



INITLR 



CUT 


BM2AD 




MVI 


A, 72 




OUT 


DM2WC 


5TRACK HEADER LENGTH 


XRA 


A 




OUT 


DM2WC 




MVI 


A,4AH 




OUT 


DMMDE 


5MODE 


LXI 


H,PGMAD+ 


73 


MOV 


A,L 




OUT 


IM3AD 


{SECTOR BODY ADDRESS 


MOV 


A,H 




OUT 


PM3AD 




MVI 


A, 185 




OUT 


DM3WC 


ISECTOR EODY WORD CO 


XRA 


A 




OUT 


LM3WC 




MVI 


A.5BH 




OUT 


LMMDE 


JMODE 


MVI 


A,40E 




OUT 


DMCST 


{COMMAND 


MVI 


A, 3 




OUT 


TMMSK 


J MASK 2-3 ON 


SIM 


1BH 




MVI 


A.WRTRK 




OUT 


FDCST 


JWRITE TRACK 


LXI 


H.ININT 




PUSH 


H 


5 INTERRUPT ADDRESS 


EI 






IN 


DM3WC 


5WAIT TIL PAST SECTO 


SBI 


93 




IN 


DM3WC 


5 UPPER ALWAYS ZERO 


JP 


WAITC 




LXI 


R f PGMAD+ 


82 


INR 


M 


J ADVANCE SECTOR 


MOV 


A,M 




CPI 


27 




JZ 


IMTLR 




IN 


DMCST 




ANI 


6 




JZ 


WAITS 


;VAIT CFANNEL 3 FCP 


JMP 


WAITC 


;go for next sector 


LXI 


H.FILTAB 




LXI 


D.PSMAD+73 
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AMC MACRO ASSEM 1.0 #031 



AMC 95/6110 SINGLE TENSITY FDC VI. 3 



e?5? 


CD9C07 


075A 


DB18 


075C 


E.608 


075E 


CA5A07 


0761 


21CA07 


0764 


11C60C 


0767 


CD9C07 


076A 


C39A0£ 


076D 


1EFC 


076F 


A3 


0770 


C2SC03 


0773 


3A070C 


0776 


4F 


0777 


E603 


2779 


21210C 


077 C 


35 


0771 


6F 


077 E 


3E00 


07S0 


3C 


07S1 


67 


0782 


3A060C 


0735 


3C 


0786 


FE4L 


0788 


CA8B03 


e?9B 


32060C 


078E 


77 


078F 


165A 


0791 


CD 370 2 


0794 


E69S 


0796 


C2FA01 



WAITT 



ININT 



LINADV 



CALL 


INIFIL 


JFILL TRAILER 1ST HALF 


IN 


DMCST 




AN I 


8 




JZ 


WAITT 


5WAIT CHANNEL 3 EO? 


LXI 


H,FILTAB 




LXI 


B,P&MAD+166 


CALL 


INIFIL 


5 FILL TRAILER 2ND HALF 


JMP 


ISSUED 


J WAIT TRACK INTERRUPT 


MVI 


E,WRMSK 


J INTERRUPT ON ENT TRACK 


ANA 


E 




JNZ 


PUTST2 


JTRACK ERROR 


LI! A 


UNIT 




MOV 


C,A 




ANI 


t? 




LXI 


E,POSN 




ADD 


L 




MOV 


L,A 




MVI 


A,0 




ADC 


a 




MOV 


H,A 




LBA 


TRACK 




INR 


A 


ADVANCE TRACK 


CPI 


77 




JZ 


PUTST3 


5END INITIALIZATION 


STA 


TRACK 




MOV 


M,A 




MVI 


D,STEP 




CALL 


ISSUE 


JSTEP IN ONE TRACK 


ANI 


98E 




JNZ 


PUTST1 


J FAULT 


IF 


TYPE EO 


6120 


MOV 


A,C 




AM 


8 




JZ 


INIADV 


ILOOP FOR NEXT TRACK 


MOV 


A.C 




ANI 


0FE 




XHI 


0CH 




OUT 


BRSEL 


5RE SELECT DOUBLE DENSITY 


LXI 


H.DINTAB 




LXI 


D,PGMAD 




CALL 


INIFIL 


JFORM DOUBLE TRACK MASK 


LM 


TRACK 




STA 


PGMAD+162 
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AMC MACRO ASSEM 1.0 #032 



AMC 95/6110 SINGLE TENSITY FDC VI. 3 



WAITD 



MOV 


A,C 




ANI 


4 




RKC 






RRC 






STA 


PGMAD+16 


3 JSIDE 


OUT 


IMCLR 


5 RESET EM A 


LXI 


H.PGMAD 




MOV 


A,L 




OUT 


DM2AD 


5TRACK HEALER ADDRESS 


MOV 


A,H 




OUT 


LM2AD 




MVI 


A, 145 




OUT 


LM2WC 


5TRACK HEADER LENGTH 


XRA 


A 




OUT 


DM2WC 




MVI 


A,4AH 




OUT 


LMMDE 


J MOLE 


LXI 


E.PGMAD+ 


146 


MOV 


A,L 




OUT 


LM3AD 


JSECTOR BOLY ALLRESS 


MOV 


A,E 




OUT 


LM3AD 




MVI 


A, 113 




OUT 


LM3WC 


JSECTOR BOLY LENGTH 


MVI 


A,l 




OUT 


LM3WC 




MVI 


A,5BH 




OUT 


DMMBE 


:mode 


MVI 


A,40H 




OUT 


DMCST 


5 COMMAND 


MVI 


A, 3 




OUT 


IMMSK 


J MASK CHANNELS 2-3 ON 


SIM 


1BE 




MVI 


A,WRTRK 




OUT 


FLCST 


JWRITE TRACK 


LXI 


R,ININT 




PUSH 


H 


INTERRUPT ADDRESS 


EI 






LXI 


1,-185 




IN 


DM3WC 


JWAIT TIL PAST SECTOR 


MOV 


L,A 




IN 


LM3WC 




MOV 


H,A 
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AMC MACRO ASSEM 1.0 



#033 



AMC 95/6110 SINGLE TENSITY FDC VI. 3 









DAB 


r 










JC 


WAITD 










LXI 


E.PGMAE+164 










INR 


M ;advance SECTOK 








MOV 


A,M 










CPI 


27 










JZ 


DNITLR ;END TRACK 






WAITE 


IN 

ANI 


TMCST 
8 










JZ 


WAITE J WAIT 


END SECTOR 








JMP 


WAITD 








DNITLR 


LXI 
LXI 


F.EILTAB 
L.PGMAD+146 










CALL 


INIFIL JFILL 


TRAILER 1ST HALF 






WAITF 


IN 
ANI 


DMCST 
S 










JZ 


WAITF JWAIT 


ENT SECTOR 








LXI 


H.LILTAB 










LXI 


B,PGMAD+331 










CALL 


INIFIL JFILL 


TRAILER 2ND HALF 








JMP 


ISSUED JWAIT 


FOR TRACK INTERRUPT 








ELSE 






0799 


C3BF06 




JMP 
ENBIF 


INIADV J LOOP 


FOR NEXT TRACK 






4 
J 


FILL 


TRACK MASK SUBROUTINE 


079C 


4E 


IMFIL 


MOV 


CM 




279D 


23 




INX 


H 




Z79T. 


7E 




MOV 


A,M 




079F 


23 




INX 


E 




07A0 


12 


INILUP 


STAX 


D 




07A1 


13 




INX 


L 




07A2 


0D 




DCR 


C 




07A? 


C2A007 




JNZ 


INILUP 




07A6 


7E 




MOV 


A,M 




07A7 


B7 




ORA 


A 




07A6 


C29C07 




JNZ 


INIFIL 




07AE 


C9 




RET 






07AC 


2BEE 


INITAB 


DB 


40,0FFH 




07AE 


06 00 




LB 


6,0 




07B0 


01EC 




DB 


l.e-FCE 
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TABLE 3-1. (Cont.) 



AMC MACRO ASSEM 1.0 



#034 



AI*C 95/6110 SINGLE DENSITY FEC VI. 3 



07B2 


1AFF 


07B4 


0600 


07B6 


eiFE 


07B8 


0200 


07EA 


0101 


07BC 


0100 


07BE 


01F7 


07C0 


0EFF 


07C2 


0600 


07C4 


01FB 


07C6 


80F5 


07CS 


01F7 


07CA 


1BFF 


07CC 


42 FF 


07CE 


00 



FILTAB 



EINTAB 



riLTAB 



BE 
EB 
EE 
DB 
EE 
DB 
EB 
EB 
EB 
EB 
EB 
EE 
EB 
EB 
DB 
IF 
EB 
DB 
DB 
EB 
DB 
DB 
EB 
EE 
EB 
DE 
EE 
DB 
EB 
DB 
DB 
DB 
DE 
DB 
EB 
EB 
EB 
FNEIF 



26 f 0FFH 

6,0 

1,01 EH 

2,0 

1,1 

1,0 

1.0F7H 

11,0FFE 

6,0 

1.0FEH 

128,0E5B 

1,0F7H 

27,0FFH 

66,0FFE 



TYPE EO 612J 

90,4EE 

12,0 

3.0F6H 

1.0FCE 

50,4EH 

12,0 

3,0F5E 

1.0FEH 

2,0 

2,1 

1,0F7E 

22,4EE 

12,0 

3,0F5E 

1,0FBE 

128, 40E 

123, 40H 

1,0F7H 

54,4EE 

131,4EH 





WORKING STORAGE 



0C00 

0C00 



ORG 

SECLEN ES 



RAMAD 
1 



:SECTOR LENGTH-1 
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TABLE 3-1. (Cont.) 



AMC MACRO AS SEP! 1.0 #03E 



AMC 95/61ie SINGLE DENSITY FPC VI. 3 



0C21 
e C£ £ 
0C06 
0C07 

i?ce3 

0C09 
0C0A 

ec0B 

0C13 
2C14 
0C1£ 
0C16 
2C20 
0C20 
0100 

ecze 



PCSiV 


rs 


4 




;iisk UNIT POSITIONS 


SECTOR 


rs 


1 




5REQUEST SECTOR 


TRACK 


ES 


1 




JEFQUEST TRACK 


UNIT 


rs 


1 




JREOUEST CNIT(AMOMG OTHER THINGS) 


EEC NT 


rs 


1 




5RETRY COUNT-1 


RETRY 


PS 


1 




JREAD/WRITE RETRY 


SKTRY 


PS 


1 




5 SEEK/HOME RETRY 


JPTAE 


PS 


3 




JJUMP TABLE(BITS 6-7 OF REQUEST) 


INTFLG 


PS 


1 




INTERRUPT FLAG 


SEC INC 


PS 


1 




5 SECTOR INCREMENT 


IOCOEE 


rs 


1 




JHSAE/WRITE COPE FOR SIDE VERIFY (6120 ONL 




ES 


RAMAP+32 


-$ 


STACK 


EOU 


$ 




5PROGKAM STACK 


PGMAE 


ECU 


$ 




JUSER PROGRAM AREA 


BUFI 


EQU 
ENE 


RAMA.L- 


► 3* 


256 JI/C BUFFER FOR BUFFEREP CCMMANES 
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the data (in sequence) from each of the 
mail -box registers. Multiple, concur- 
rent disk unit operations cannot be 
performed. Depending on the command, 
the data from the other mail -box regis- 
ters are used as operating parameters 
when the specified sequence of disk 
unit operations are performed. Each 
request is terminated by return of a 
status byte through the status register 
(R4), signifying completion, and (when 
errors occur) the error condition. The 
Command bit flip-flop is reset, waiting 
for the next command. 



with a write operation; R4 is available 
coincident with a read operation. 

For example, if the port address is 
7CH, the register addresses (coincident 
with an output instruction) are 7CH 
through 7FH for registers R0 through 
R4, respectively. The status register 
(R4) is addressed by 7FH (coincident 
with an input instruction). Registers 
R3 and R4 appear to have the same ad- 
dress. However, because R3 is assoc- 
iated with an output operation and R4 
is associated with an input operation, 
no conflict is introduced. 



3-5. FIRMWARE INVOCATION 

The firmware is initiated by a reset. 
It initially performs a confidence test 
before accepting commands. The confi- 
dence test initially writes a status 
byte of 0F to the status register R4 
and subsequently clears each bit as the 
respective test completes successfully. 
The four tests, represented by status 
bits 0-3 are: RAM, ROM, DMA, and 1771 
FDC. At the conclusion of all four 
tests, one of two procedures occur: If 
any of the tests failed, the COMPLETE 
flag is set and the firmware enters the 
host command wait loop. If no errors 
occur, the firmware does a STATUS re- 
quest on drive zero and returns the 
same result as if requested by the 
host. If the SID line is low, the 
firmware automatically reads one sector 
at single density from side 0, track 
0, sector 1 of drive zero, into host 
memory address and releases the host 
CPU to execute the content of the 
sector. 



3-7. MAIL-BOX REGISTERS 

Registers R0 through R3 are written by 
the master CPU and read by the on-board 
CPU. R4 is written by the on-board CPU 
and read by the master CPU. Registers 
R0, Rl, and R2 are general purpose re- 
gisters for parameter input. Register 
R3 is used as the command register. 
Register 4 is used as the status re- 
gister. 

Use of the mail -box registers is shown 
in table 3-2. 



3-8. Unit Code 

The Unit code is shown in figure 3-1. 



Drive Select 
drive 



specifies the disk 



Side Select: specifies the side of a 
double-sided disk 



3-6. SYSTEM BUS INTERFACE 

The FDC interfaces with the host CPU 
through edge connector PI. Information 
is exchanged through the mail -box reg- 
isters (R0-R4). The FDC board address 
is selectable and is established 
through setting switches SW1 through 
SW6. Five registers are selectable 
with the remaining two bits. R0 
through R3 are available coincident 



Retries: enables or disables the 
automatic retry feature. 

Data Transfer: specifies the mode in 
which data is transferred between the 
host CPU and the disk drive. When in 
direct mode (0), the DMA must initiate 
a bus request for each byte. When in 
buffered mode (1), 128 bytes are 
transferred from master memory to 
buffer memory with one DMA bus request, 
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TABLE 3-2. MAILBOX REGISTER FUNCTIONS. 



Command 


RO 


Rl 


R2 


R3 


R4 


HOME 


UNIT CODE 


_ 


_ 





STATUS 


SETPAR 


UNIT CODE 


TRACK 


SECTOR 


1 


STATUS 


STATUS 


UNIT CODE 


- 


- 


2 


STATUS 


CLRINT 


- 


- 


- 


3 


STATUS 


INIDSK 


UNIT CODE 


- 


- 


4 


STATUS 


INTUNT 


- 


- 


- 


5 


STATUS 


INTRK 


- 


- 


- 


6 


STATUS 


INTSEC 


- 


- 


- 


7 


STATUS 


READ 


PAGE SEGMENT 


MSB 
(DATA ADDR) 


LSB 
(DATA ADDR) 


4X 


STATUS 


WRITE 


PAGE SEGMENT 


MSB 
(DATA ADDR) 


LSB 
(DATA ADDR) 


8X 


STATUS 


EXECUTE 


PAGE SEGMENT 


MSB 
(PROGRAM ADDR) 


LSB 
(PROGRAM ADDR) 


CX 





Note: The "-" symbol is used in this table as "don't care" 
commands are represented as "shorthand" hexadecimal values; 
description of the command code structure. 



In column R3, the 
see figure 3-2 for a 



7 6 5 4 3 2 




Bit Number 



Drive Select 



00 
01 
10 
11 



Select 
Select 
Select 
Select 



Drive 
Drive 1 
Drive 2 
Drive 3 



Side Select 



Retries 



Select 

1 Select 1 



No retries 

1 Retry 5 times for HOME or SEEK operation 
Retry 9 times for READ or WRITE operation 



Data Transfer 



Interrupt 



Interlace 



Transfer disk directly to host memory 

1 Buffer disk data through 6110 memory 

Note: Transferring directly to the host 
provides greater capability between sec- 
tors, but cannot be used effectively in 
a multi -master configuration because of 
possible lost data, if the bus is usurp- 
ed. Buffered mode allows multi -master 
usage since the transfer is memory-to- 
memory via DMA, which can be inter- 
rupted by the priority bus interrupt. 

No interrupt at end of operation 

1 Interrupt at end of operation 

Contiguous sectors, 1/1 

1 Alternate sectors, 2/1 



Figure 3-1. Unit Code. 
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then the data is transferred from 
buffer memory to disk; or 128 bytes of 
data are transferred from disk to 
buffer memory, then under a single DMA 
bus request transferred to master 
memory. 



tranfer. The code extends the memory 
address from 16 bits to 20 bits. Page 
code values may be from 00 to FFH. 
The derivation of a 20-bit DMA address 
is illustrated in figure 3-3. 



Interrupt: specifies whether the 
operation complete function will 
generate an INTERRUPT REQUEST on the 
MULTIBUS. 

Interlace: specifies the sequence 
in which the sectors are selected when 
a multi-sector transfer is requested. 



3-13. MSB Data Address Code 

The MSB data address code is an 8-bit 
value representing the high-order byte 
of the main memory address where the 
first byte of data to be transferred is 
located. This is applicable to the 
READ and WRITE commands. 



3-9. Track Select Code 

The track select code specifies the 
floppy disk track to be accessed. 
Seven bits are used to specify a value 
from to 76. Bit is the least 
significant bit. 



3-14. LSB Data Address Code 

This is also an 8-bit value to be 
as the low-order byte of the 
address. 



used 
data 



3-10. Sector Select Code 

The sector select code specifies the 
starting sector in the selected track. 
Five bits are used to specify a value 
from 1 through 26. Bit is the least 
significant bit. 



3-11. Command Code 

The command code specifies the command 
to be performed. This consists of a 
one-byte value. The value is listed in 
table 3-2. The READ and WRITE commands 
contain additional information to 
specify a sector count for the data 
transfer. The EXECUTE command contains 
additional information to specify a 
memory block count (64-byte blocks). 

Figure 3-2 illustrates the construction 
of the command code. 



3-12. Page Segment Code 

The page segment code specifies the 
memory segment to be used for a data 



3-15. MSB Program Address 

This is an 8-bit code similar to the 
MSB data address code. Together with 
the LSB program address code it 
represents the first byte of data in 
master memory to be transferred to the 
on-board memory for execution by the 
on-board CPU. 



3-16. LSB Program Address 

This is an 8-bit value used as the 
low-order byte of the program address. 
This address is applicable to the EX- 
ECUTE command. 



3-17. Status Byte 

The status byte is returned to register 
R4 upon completion of an operation. 
This mail -box register may be read by 
the host CPU. The format of the status 
byte is illustrated in figure 3-4. When 
a command does not use a particular bit 
of the status byte, a zero is returned 
at that bit position. 
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BASIC COMMANDS 
7 6 5 4 3 2 10 



n n n 



READ COMMAND 
7 6 5 4 3 2 11 



1s s s s s s 



WRITE COMMAND 
7 6 5 4 3 2 10 



1 s s s s s s 



EXECUTE COMMAND 
7 6 5 4 3 2 10 



1 1 b b b b b b 



nnn 

1 
2 
3 
4 
5 
6 
7 



command 
HOME 

SET PARAMETERS 
STATUS 
CLRINT 
INIDSK 
INTUNT 
INTRK 
INTSEC 



ssssss = sector count -1, 

from through 63 to specify 
from 1 through 64 sectors, 
respectively. 



ssssss = sector count -1 
as defined for read. 



bbbbbb = count of 64-byte blocks 
of memory -1, from through 
63 to specify from 1 through 
4096 (64 x 64) bytes, respect- 
ively. 



Figure 3-2. Command Codes. 



3-18. COMMAND DESCRIPTIONS 



3-19. HOME COMMAND 

This command positions the read/write 
head of a selected drive unit over 
track zero. 



Processing 



Call Sequence: 



Returns 



R0 Unit code 

Rl not used 

R2 not used 

R3 



The head restore func- 
tion is performed by 
the selected drive. 
The restore is retried 
according to the retry 
bit (unit code bit 4) 
until successful . 

The operation status is 
placed in R4. If bit-6 
of the unit code was 
set, an interrupt is 
generated. 
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15 14 13 12 11 10 9 



7 6 5 4 3 2 10 



MSB 



Y Y Y Y 
7 6 5 4 3 2 10 



YYVYYVYYYY YYYYYYVYVY 



LSB 



ADDRESS 



PAGE 



19 18 17 16 15 14 13 12 11 10 9 



7 6 5 4 3 2 10 



<- 



20-bit address 



DMA 



Figure 3-3. Page Segment Code. 



7 6 5 4 3 2 10 <--- Bit Number 




















Seek CRC error 

Seek error 

Read/write lost data or write fault 




Read/write CRC error 




Sector not found or = single sided 




disk; 1 = double sided disk installed 
Write protect 




Unit not ready 




Operation complete 


Note: Bit 
error occu 
combinatio 
and 2 repr 
vice busy 
zero; othe 


s 0-1 and 2-4 represent mutually exclusive operations, i.e., if a seek 
rs, no subsequent read/write operations take place. Therefore, a 
n of bits from the two groups is used to diagnose common faults. Bits 
esent an illegal operation, and bits 1 and 2 represent a time out on de- 
or lost interrupt. Bit 3 is interpreted as a data error if bit 4 is 
rwise, it is an address error. 



Figure 3-4. Status Byte. 
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3-20. SET PARAMETERS COMMAND 



This command sets 
information for a 
WRITE operation. 



the device address 
subsequent READ or 



Call Sequence 



Processing 



Returns 



R0 Unit Code 

Rl Track Select Code 

R2 Sector Select Code 

R3 1 

The parameters are 
stored for later use; 
the unit is selected. 

R4 contains a value of 
80H. If bit-6 of the 
unit code was set, an 
interrupt will be 
generated. 



3-21. STATUS COMMAND 

This command causes R4 to be loaded 
with the selected device status. 



Call Sequence 



Processing 



Returns 



R0 Unit Code 

Rl not used 

R2 not used 

R3 2 

The designated drive 
unit is selected and 
its status read into 
R4. 

R4 contains status bits 
4-7. The other bits 
are undefined. If 
bit-6 of the unit code 
was set, an interrupt 
wil 1 be generated. 



R2 not used 
R3 3 

Processing: The interrupt latch is 
cleared. 

Returns: R4 contains a value of 
80H. 



3-23. INITIALIZE DISK COMMAND 

This command writes track and sector 
address information to all tracks and 
sectors. The data areas are written 
with a hexadecimal E5 code; the bit 
pattern of E5H is 11100101. 



Call Format: 



Processing 



Returns 



R0 Unit Code 

Rl not used 

R2 not used 

R3 4 

The disk unit is homed 
and al 1 sectors are 
written with initialize 
information (E5H) to 
permit normal use of the 
disk. The format is IBM 
3740, 128 bytes per sec- 
tor, single sided, sin- 
gle density. Completion 
of this operation leaves 
the read/write head po- 
sition over track 76. 

R4 contains the status 
byte. If bit-6 of the 
unit code was set, an 
interrupt will be gen- 
erated. 



3-22. CLEAR INTERRUPT COMMAND 



This command 
set at the 
operation. 

Call Format: 



clears the interrupt latch 
completion of a previous 



R0 
Rl 



not used 
not used 



3-24. INTERROGATE UNIT COMMAND 

This command returns unit information 
for the currently selected disk. 



Cal 1 Format 



R0 not used 

Rl not used 

R2 not used 

R3 5 
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Processing: The unit code, except 
for the interlace bit, 
is returned to the user, 
and a clear interrupt is 
performed. 

Returns: R4 contains the unit 
code, except for bit- 7, 
which is used for the 
status bit-7 function 
(operation complete). 



3-25. INTERROGATE TRACK COMMAND 

This command returns the track select 
code previously requested or as updated 
by the intervening I/O. 



Call Format 



Processing 



R0 not used 

Rl not used 

R2 not used 

R3 6 

The track code current- 
ly existing in the con- 
troller is returned to 
the user. This value, 
together with the Cur- 
rent Sector code, can be 
used, when an eror con- 
dition occurs, to de- 
termine the track and 
sector in error. A 
clear interrupt oper- 
ation is also performed. 

R4 contains the track 
code in bits 0-6 and 
the operation-complete 
status bit in bit-7. 



3-26. INTERROGATE SECTOR 
COMMAND 

This command returns the sector select 
code previously requested or as updated 
by the intervening I/O. 



Returns 



Call Format 



R0 not used 

Rl not used 

R2 not used 

R3 7 



Processing: The sector code current- 
ly existing in the con- 
troller is returned to 
the user. This value, 
together with the cur- 
rent track code, may be 
used when an error con- 
dition occurs, to de- 
termine the track and 
sector in error. A 
clear interrupt , opera- 
tion is also performed. 

Returns: R4 contains the sector 
code in bits 0-4, bits 
5 and 6 have values of 
zero, and bit 7 has a 
value of 1. 



3-27. READ COMMAND 

This command reads from 1 to 64 con- 
secutive sectors beginning at the pre- 
viously selected unit, track, and sec- 
tor. The command is normally preceded 
by a SET PARAMETER command. However, 
when the prior values are known to be 
correct, the SET PARAMETERS command is 
not required. 

Call Format: R0 Page Segment 

Rl Data Address MSB 

R2 Data Address LSB 

R3 Command Code (4X) 

(figure 3-2) 

Processing: One through 64 consecu- 
tive sectors can be read 
into the host address, 
either directly or 
sector buffered de- 
pending on the unit 
code, bit 4. The head 
location is automati- 
cally incremented to the 
next sector/track ad- 
dress. If end of disk 
occurs during the trans- 
fer, the transfer is 
prematurely terminated 
with no indication, 
other than loss of data. 
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If an unrecoverable er- 
ror occurs, operations 
are prematurely ter- 
minated with an error 
status. The value x in 
the command code is six 
bits where 0-63 re- 
present the number of 
sectors to be read 
(1-64). Internally, the 
host memory address page 
is shifted 12 bits and 
added to the R1-R2 ad- 
dress to determine the 
host absolute address. 
During the transfer, the 
host address is advanced 
by sector length but the 
page is not. Therefore, 
an offset wraparound may 
occur if the number of 
sectors times sector 
length plus offset ad- 
dress exceeds 16 bit 
capacity. The host must 
determine when this will 
occur and issue multiple 
commands to update the 
page as necessary. 

Returns: R4 contains the status 
byte. If bit-6 of the 
unit code was set, an 
interrupt will be gen- 
erated. 



3-28. WRITE COMMAND 

This command writes from one to sixty- 
four consecutive sectors beginning at 
the previously stored unit, track, and 
sector. The command is normally pre- 
ceded by a SET PARAMETER command to de- 
signate unit, track, and sector. How- 
ever, when the prior values are known 
to be correct, the SET PARAMETERS com- 
mand is not required. 



Call Format: 



R0 Page Segment 
Rl Data Address MSB 
R2 Data Address LSB 
R3 Command Code (8X) 
(figure 3-2) 



Processing: One through sixty-four 
consecutive sectors can 
be written from the host 
memory address, either 
directly or sector buf- 
fered depending on the 
unit code bit 4. End of 
disk, error considera- 
tions, and addressing 
considerations are the 
same as READ. 



3-29. EXECUTE PROGRAM 
COMMAND 

This command can transfer from 64 to 
4096 bytes of program code from a host 
memory address to the 6110 RAM, start- 
ing address of 0C20H and begin ex- 
ecution at this same address. However, 
the standard 611(21 RAM capacity is 1024 
bytes. Since the starting address in 
RAM is 0C20H and ending at 1000H, 
the usable capacity is 992 bytes. Also, 
since transfers are made in 64 byte 
groups, 15 groups would comprise 960 
bytes. To use the full capability of 
the command, the off board RAM ex- 
tension memory capability would have to 
be employed. 

Call Format: R0 Page Segment 

Rl Program Address MSB 
R2 Program Address LSB 
R3 Command Code (CX) 
(figure 3-2) 

Processing: One through 64 blocks of 
64 bytes of program data 
are transferred from the 
host memory to the 6110 
RAM and executed. This 
function is used to ex- 
ecute controller pro- 
grams that are located 
in the 6110 ROM. The 
controller firmware uses 
addresses 0F00-0FFF as a 
sector buffer during 
buffered 1/0 transfers. 
The value x in the 
command is 6 bits 0-63 
representing 1-64 blocks 
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Return: 



of 64 bytes. A user pro- 
gram may be terminated 
by transferring to the 
firmware location a 39 
hexadecimal (the normal 
command loop). The pro- 
gram stack, on entry to 
the user program, is 10 
bytes in length and emp- 
ty. It should be left 
empty on return to loca- 
tion 39. The user pro- 
gram must provide any R4 
response required by the 
host following the com- 
pletion of transfer and 
start of execution. 

No return code is 
provided. One may be 
provided by the user 
program. 



3-32. Am9085A MICROCOMPUTER 

The Am9085A is an 8-bit general -purpose 
microcomputer capable of accessing up 
to 64K bytes of memory and executing 
code byte-by-byte. The code executed 
by the Am9085 resides in the FDC on 
board E-PROMs, memory locations 
0000-0BFF. The CPU chip is con- 
trolled exclusively by the firmware and 
the system CPU does not have access to 
control this device. Because of the 
complexity of the Am9085 and the var- 
ious ways it can be used, and because 
many books and descriptions are cur- 
rently in publication, it would be re- 
dundant to repeat that data here. If 
detailed information on the Am9085A CPU 
chip is required, consult the Am9080 
user's manual. However, table 3-3, 
Am9085A Instruction Set, is provided 
for user convenience. 



3-30. FIRMWARE INSTRUCTIONS 

Table 3-2 is a listing of the 
Am95/6110 firmware instructions stored 
in the FDC board E-PROMs. Included 
with the listing are appropriate com- 
ments. 



3-31. PROGRAMMING INTRODUCTION 

The previous paragraphs describe the 
firmware that is installed in the 
standard Am95/6110 board and how each 
command is implemented. Included on 
the FDC board are programmable devices 
that are controlled by the firmware. 
When and if the factory supplied 
firmware is modified, the user must 
realize the interrelationships to these 
programmable chips. Therefore, the 
following paragraphs provide some 
operation and programming information 
to aid user understanding of these 
devices. When greater detailed 
descriptions are required, consult the 
data sheet for the specific device. 
The programmable devices on the AMC 
95/6110 FDC board are: Am9085 CPU, 
Am9517 DMA, and FD 1771 FDC. 



3-33. MULTIMODE DIRECT MEMORY 
ACCESS (DMA) CONTROLLER 
Am9517A 

The Am9517 DMA controller provides the 
FDC board with the capability to trans- 
fer data to/from the FDC board and main 
memory and to route data on the board 
using four separate channels. The data 
channels can be programmed to perform 
single transfer mode or block transfer 
mode. 



3-34. SINGLE TRANSFER MODE 

When in the single transfer mode, the 
Am9517 is programmed to make a single 
byte transfer. The word count is de- 
cremented/incremented following each 
transfer. A terminal count (TC), re- 
ached when the word count is zero, 
causes an autoinitialize when the chan- 
nel is so programmed. 



3-35. BLOCK TRANSFER MODE 

When using the block transfer mode, the 
Am9517 is programmed to continue making 
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TABLE 3-3. Am9085 Instruction Set. 



Hex 


Mnemonic 


Hex 


Mnemonic 


Hex 


Mnemonic 


Hex 


Mnemonic 


Function 


40 


MOV B,B 


58 


MOV E,B 


70 


MOV M,B 


1A 


LDAX D 


DATA 


41 


MOV B,C 


59 


MOV E,C 


71 


MOV M,C 


2A 


1HLD 




42 


MOV B,D 


5A 


MOV E,D 


72 


MOV M,D 


3A 


LDA 




43 


MOV B,E 


5B 


MOV E,E 


73 


MOV M,E 


02 


STAX B 


TRANSFER 


44 


MOV B,H 


5C 


MOV E,H 


74 


MOV M,H 


12 


STAX D 




45 


MOV B,L 


5D 


MOV E,L 


75 


MOV M.L 


22 


SHLD 




46 


MOV B,M 


5E 


MOV E,M 


77 


MOV M,A 


32 


STA 




47 


MOV B,A 


5F 


MOV E,A 


78 


MOV A,B 


01 


LXI B 




48 


MOV C,B 


60 


MOV H,B 


79 


MOV A,C 








49 


MOV C,C 


61 


MOV H,C 


7A 


MOV A,D 


21 


LXI H 




4A 


MOV C,D 


62 


MOV H,D 


7B 


MOV A,E 


31 


LXI SP 




4B 


MOV C,E 


63 


MOV H,E 


7C 


MOV A,H 


F9 


SPHL 




4C 


MOV C,H 


64 


MOV H,H 


7D 


MOV A,L 


E3 


XTHL 




4D 


MOV C,L 


65 


MOV H,L 


7E 


MOV A,M 


EB 


XCHG 




4E 


MOV C,M 


66 


MOV H,M 


7F 


MOV A,A 


D3 


OUT 




4F 


MOV C,A 


67 


MOV H,A 


06 


MVI B 


DB 


IN 




50 


MOV D,B 


68 


MOV L,B 


0E 


MVI C 


C5 


PUSH B 




51 


MOV D,C 


69 


MOV L,C 


16 


MVI D 


D5 


PUSH D 




52 


MOV D,D 


6A 


MOV, L,D 


1E 


MVI E 


E5 


PUSH H 




53 


MOV D,E 


6B 


MOV L,E 


26 


MVI H 


F5 


PUSH PSW 




54 


MOV D,H 


6C 


MOV L,H 


2E 


MVI L 


C1 


POP B 




55 


MOV D,L 


6D 


MOV L,L 


36 


MVI M 


D1 


POP D 




56 


MOV D,M 


6E 


MOV L,M 


3E 


MVI A 


E1 


POP H 




57 


MOV D,A 


6F 


MOV L,A 


0A 


LDAX B 


F1 


POP PSW 




80 


ADD B 


C6 


ADI 


9E 


SBB M 


3C 


INR A 


ARITHMETIC 


81 


ADD C 


CE 


ACI 


9F 


SBB A 


03 


INX B 




82 


ADD D 


90 


SUB B 


D6 


SUI 


13 


INX D 




83 


ADD E 


91 


SUB C 


DE 


SBI 


23 


INX H 




84 


ADD H 


92 


SUB D 


09 


DAD B 


33 


INX SP 




85 


ADD L 


93 


SUB E 


19 


DAD D 


05 


DCR B 




86 


ADD M 


94 


SUB H 


29 


DAD H 


0D 


DCR C 




87 


ADD A 


95 


SUB L 


39 


DAD SP 


15 


DCR D 




88 


ADC B 


96 


SUB M 


27 


DAA 


1D 


DCR E 




89 


ADC C 


97 


SUB A 


04 


INR B 


25 


DCR H 




8A 


ADC D 


98 


SBB B 


OC 


INR C 


2D 


DCR L 




8B 


ADC E 


99 


SBB C 


14 


INR D 


35 


DCR M 




8C 


ADC H 


9A 


SBB D 


1C 


INR E 


30 


DCR A 




8D 


ADC L 


9B 


SBB E 


24 


INR H 


0B 


DCX B 




8E 


ADC M 


9C 


SBB H 


2C 


INR L 


1B 


DCX D 




8F 


ADC A 


9D 


SBB L 


34 


INR M 


2B 
3B 


DCX H 
DCX SP 
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TABLE 3-3. Am9085 Instruction Set. (Cont.) 



Hex 


Mnemonic 


Hex 


Mnemonic 


Hex 


Mnemonic 


Hex 


Mnemonic 


Function 


AO 


ANA B 


A9 


XRA C 


B2 


ORA D 


BB 


CMP E 


LOGICAL 


A1 


ANA C 


AA 


XRA D 


B3 


ORA E 


BC 


CMP H 




A2 


ANA D 


AB 


XRA E 


B4 


ORA H 


BD 


CMP L 




A3 


ANA E 


AC 


XRA H 


B5 


ORA L 


BE 


CMP M 




A4 


ANA H 


AD 


XRA L 


B6 


ORA M 


BF 


CMP A 




A5 


ANA L 


AE 


XRA M 


B7 


ORA A 


FE 


CPI 




A6 


ANA M 


AF 


XRA A 


F6 


ORI 


07 


RLC 




A7 


ANA A 


EE 


XRI 


BB 


CMP B 


OF 


RRC 




E6 


AN I 


BO 


ORA B 


B9 


CMP C 


17 


RAL 




A8 


XRA B 


B1 


ORA C 


BA 


CMP D 


1F 
2F 


RAR 
CMA 




C3 


JMP 


E9 


PCW L 


CD 


CAL L 


C9 


RET 


BRANCHING 


C2 


JNZ 


C7 


RST 


C4 


CNZ 


CO 


RNZ 




CA 


JZ 


CF 


RST 1 


CC 


CZ 


C8 


RZ 




D2 


JNC 


D7 


RST 2 


DA 


CNC 


DO 


RNC 




DA 


JC 


DF 


RST 3 


DC 


CC 


D8 


RC 




E2 


JPO 


E7 


RST 4 


E4 


CPO 


E0 


RPO 




EA 


JPE 


EF 


RST 5 


EC 


CPE 


E8 


RPE 




F2 


JP 


F7 


RST 6 


F4 


CP 


F0 


RP 




FA 


JM 


FF 


RST 7 


FC 


CN 


F8 


RM 




00 


NOP 


F3 


Dl 


37 


STC 


3F 


CMC 


CONTROL 


76 


HLT 


FB 


El 













transfers upon activation of the DREQ 
signal until a terminal count, caused 
by the word count going to zero, or an 
external end of process signal. 



3-36. ADDRESSING 

The Am9517 DMA controller uses 16 
consecutive addresses (10H through 
1FH) for reading and writing to the 
twelve internal registers. The port 
addresses and their functions are 
1 isted in table 3-4. 



3-37. REGISTERS 

The Am9517 DMA controller's twelve 
addressable registers are listed in 
table 3-5. These register addresses 
are listed in table 3-4 and their 
functions are described in the 



3-38. Command Register 

This 8-bit register controls the 

operation of the Am9517. It is 

programmed by the Am9085 and is cleared 

by Reset. The port address of the 

command register is 18H and IOW active. 

The function of each command bit is 
illustrated in figure 3-5. 



following paragraphs. 



3-39. Mode Register 

Each of the four channels has its own 
6-bit mode register. When the Am9085 
is writing into this register, bits 
and 1 determine which channel mode 
register is to be written. The port 
address of the mode registers is 1BH 
and IOW active. The bit assignment and 
definition are shown in figure 3-6. 
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TABLE 3-4. DMA (Am9517) I/O PORT ADDRESSES. 



I/O Port 


Input Function (IOW) 


Output Function (IOR) 


10 


Channel Address 




11 


Channel Word Count 




12 


Channel 1 Address 




13 


Channel 1 Word Count 




14 


Channel 2 Address 




15 


Channel 2 Word Count 




16 


Channel 3 Address 




17 


Channel 3 Word Count 




18 


STATUS REGISTER 


Command Register 


19 


Not used 


Request Register 


1A 


Not used 


SET/RESET 


IB 


Not used 


MODE REGISTER 


1C 


Not used 


CLEAR FIRST/LAST FLIP-FLOP 


ID 


Temporary Register 


MASTER CLEAR 


IE 


Not used 


Not used 


IF 


Not used 


MASK REGISTER FOUR BITS 



TABLE 3-5. Am9517 INTERNAL REGISTERS. 



Name 


Size 


Number 


Base Address Registers 


16 bits 


4 


Base Word Count Registers 


16 bits 


4 


Current Address Registers 


16 bits 


4 


Current Word Count Registers 


16 bits 


4 


Temporary Address Register 


16 bits 


1 


Temporary Word Count Register 


16 bits 


1 


Status Register 


8 bits 


1 


Command Register 


8 bits 


1 


Temporary Register 


8 bits 


1 


Mode Registers 


6 bits 


4 


Mask Register 


4 bits 


1 


Request Register 


4 bits 


1 



3-40. Request Register 

The Am9517 can respond to requests for 
DMA service which are initiated by 
software as well as by a DREQ. Each 
channel has a request bit associated 
with it in the four bit register. Each 
register bit is set or reset separately 
under software control or as cleared on 
generation of a terminal count or end 
of process. The port address of the 
request register is 19H and IOR active. 



To set or reset a bit, the software 
loads the proper form of the data word, 
shown in figure 3-7. 

3-41 . Mask Register 

Each channel has associated with it a 



mask bit which can 
the incomming DREQ. 
when its associated 
end of process and 
programmed for 



be set to disable 

Each mask bit sets 

channel produces an 

the channel is not 

autoinitial ization. 
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7 6 5 4 3 2 10 <— Bit Number 




















Memory-to-memory disable 

1 Memory-to-memory enable 

Channel address hold disable 

1 Channel address hold enable 
X If bit = 

Controller enable 




1 Control ler disable 
Normal timing 




1 Compressed timing 
X If bit = 1 

Fixed priority 




1 Rotating Priority 
Late write selection 




1 Extended write selection 
X If bit 3 = 1 

DREQ sense active high 




1 DREQ sense active low 
DACK sense active low 




1 DACK sense active high 



Figure 3-5. Am9517 Command Register. 



Each bit of the four bit mask register 
can be set or cleared separately under 
software control . 

The entire register is set by Reset, 
which disables all DMA requests until a 
clear mask register instruction allows 
them to occur. The port address to set 
individual bits is 1AH with IOR active 
and when all four bits are written with 
a single command, address port IFH and 
IOW active. The bit configuration and 
definitions are shown in figure 3-8. 



3-42. Status Register 

The status register contents are avail- 
able to be read out by addressing port 
18 and activating IOR. It contains the 



device status which includes the chan- 
nels that have reached a tunnel count 
and which channels have pending DMA re- 
quests. Bits 0-3 are set each time a 
terminal count is reached by the appro- 
priate channel. These bits are cleared 
upon Reset and on each Status Read. 
Bits 4-7 are set when the corresponding 
channel request services. Figure 3-9 
shows the bit configuration of the 
Status Register. 



3-43. Temporary Register 

The temporary register resides at ad- 
dress port ID and holds data during 
memory-to-memory transfers. When the 
transfer is complete, the last word 
moved can be read by the microproces- 
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7 6 5 4 3 2 10 <--- Bit Number 






















00 Channel select 
01 Channel 1 select 

10 Channel 2 select 

11 Channel 3 select 

00 Verify transfer 

01 Write transfer 






10 Read transfer 

11 Illegal 

XX If bits 6 and 7 = 11 

Autoinitial ize disable 






1 Autoinitial ize enable 
Address increment select 






1 Address decrement select 

00 Demand mode select 

01 Single mode select 






10 Block mode select 

11 Cascade mode select 



Figure 3-6. Am9517 Mode Register Bit Assignments. 



7 6 5 4 3 2 10 <--- Bit Number 




Don't Care 






00 Select channel 

01 Select channel 1 

10 Select channel 2 

11 Select channel 3 

Reset request bit 




1 Set request bit 



Figure 3-7. Am9517 Request Register. 
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SET/RESET 

7 6 5 4 3 2 10 



< — Bit Number 



Don't Care 



00 Select 

01 Select 

10 Select 

11 Select 



channel 
channel 
channel 
channel 



mask bit 

1 mask bit 

2 mask bit 

3 mask bit 



Clear mask bit 

1 Set mask bit 



4-bit MASK 

7 6 5 4 3 2 10 <— - Bit Number 



Don't Care 



Clear Channel mask bit 

1 Set Channel mask bit 

Clear Channel 1 mask bit 

1 Set Channel 1 mask bit 

Clear Channel 2 mask bit 

1 Set Channel 2 mask bit 

Clear Channel 3 mask bit 

1 Set Channel 3 mask bit 



Figure 3-8. Am9517 Mask Register. 



sor. This register always contains the 
last byte transferred in the previous 
memory-to-memory operation, unless 
cleared by a Reset. 



3-44. SOFTWARE COMMANDS 

There are two additional software com- 
mands that can be executed on the 
Am9517 that do not depend on any speci- 
fic bit pattern on the data bus. These 
two commands are described in the fol- 
lowing paragraphs and the address codes 
are shown in table 3-6. 



3-45. Clear First/Last Flip/Flop 

This command is executed prior to writ- 
ing or reading new address or word 
count information to the Am9517. This 
initializes the flip/flop to a known 
state so that subsequent accesses to 
register contents by the microprocessor 
will address upper and lower bytes in 
the correct sequence. 



3-46. Master Clear 

This software instruction has the same 
effect as the hardware Reset. The 
Command, Status, Request, Temporary, 
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7 6 5 4 3 2 10 <--- Bit Number 



1 Channel has reached TC 

1 Channel 1 has reached TC 

1 Channel 2 has reached TC 

1 Channel 3 has reached TC 

1 Channel request 

1 Channel 1 request 

1 Channel 2 request 

1 Channel 3 request 



Figure 3-9. Am9517 Status Register Configuration. 



TABLE 3-6. SOFTWARE COMMAND CODES. 



Operation 


Registers 




Signal s 












Affected 


CS 


IOR IOW 


A3 


A2 


Al 


A0 


Clear FF 


Internal 

First/Last 

Flip/Flop 





1 


1 


1 








Master 


Clear: 





1 


1 


1 





1 


Clear 


Command 

Status 

Request 

Temporary 

Internal 

First/Last 

Flip/Flop 

Set: Mask 















and Internal First/Last Flip/Flop 
registers are cleared and the Mask 
register is set. The Am9517 will enter 
the Idle cycle. 



3-47. FLOPPY DISK FORMATTER/ 
CONTROLLER FD1771 

The FD1771 is a MOS/LSI device that 
performs the functions of a floppy disk 
controller/ formatter. The device is 
included in the floppy disk controller 
board, and contains a flexible inter- 
face organization that accomodates the 
firmware interface and the disk drive 
interface. 



The firmware/processor interface con- 
sists of an 8-bit bidirectional bus for 
data, status, and control word trans- 
fers. The device operates on a multi- 
plexed bus with other bus-oriented 
devices. 



3-48. PROCESSOR INTERFACE 



The FD1771 
interface is 
eight Data Access 
associated control 
status, and control 
into the FD1771 use 
contains three state 



to Am9085 processor 

accomplished through the 

Lines (DAL) and 

signals. Data, 

words out of or 

the DAL. The DAL 

buffers, which are 
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enabled as output drivers when Chip 
Select and Read Enable are active, and 
enabled as input receivers when Chip 
Select and Write Enable are active. 

When data transfer through the FD1771 
is required by the Am9085, the device 
address is decoded making the Chip 
Select (CS) line active. The four 
address parts on the FD1771 and the 
accessed registers are listed in table 
3-6. The least significant address 
bits A0 and Al are coded to select the 
registers listed. 

During DMA types of transfers between 
the FD1771 Data Register and the buffer 
or main memory, the Data Request (DRQ) 
output is used in Data Transfer Con- 
trol. This signal also appears as 
status bit 1 during read and write 
operations. 



3-49. FLOPPY DISK INTERFACE 

The floppy disk interface consists of 
head positioning controls, write gate 
controls, and data transfer lines. A 
2.0MHz +1% squarewave clock is required 
at the CLK input for internal control 
timing. Commands read into the FD1771 
from the Am9085 are implemented and the 
appropriate signals are sent to a 
selected disk drive. 



3-50. COMMAND DESCRIPTION 

The FD1771 accepts and executes eleven 
commands. The command words should be 
loaded into the command register only 
when the busy status bit is off (Status 
Bit 0). An exception is the Force 
Interupt command. When a command is 
being executed, the busy status bit is 
set. When a command is completed, an 
interrupt is generated and the Busy 
Status bit is reset. The status 
register indicates whether a command is 
computed or an error occured. The 
commands are divided into four types 
and are explained in the following 
paragraphs. 



3-51. Restore (Seek Track 0) 

When this command is read into the com- 
mand register and execution is imple- 
mented, the track 00 (TROO) input is 
sampled. If TROO is active, indicating 
the Read/Write head is positioned over 
track 0, the track register is filled 
with zeroes and an interrupt is gener- 
ated. If TROO is not active, stepping 
pulses, at a rate specified by bits 
and 1, are sent to the drive unit until 
TROO is activated. At this time the TR 
is filled with zeroes and an interrupt 
is generated. If the TROO does not 
activate after 255 stepping pulses, the 
operation is terminated automatically, 
the interrupt is set, and the seek er- 
ror status bit is set. A verifica- 
tion operation occurs if bit 2 of the 
command is set. The Restore command is 
implemented automatically when the 
master reset occurs. Figure 3-10 il- 
lustrates the bit configuration of the 
command register for a RESTORE command. 



3-52. SEEK 

This command assumes the track register 
contains the current Read/Write head 
track position and the data register 
contains the desired track number. The 
FD1771 updates the track register and 
issues stepping pulses in the proper 
direction, positioning the Read/Write 
head, until the contents of the track 
register equal the data register. At 
this point the Read/Write head is posi- 
tioned over the desired track. An 
interrupt is generated at the end of 
this operation. Figure 3-11 illu- 
strates the command register bit con- 
figuration for a SEEK command. 



3-53. STEP 

Upon receipt of this command, the 
FD1771 issues one stepping pulse to the 
disk drive. The stepping motor direc- 
tion is determined by a previously is- 
sued STEP IN or STEP OUT command. An 
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7 6 5 4 3 2 10 <-— Bit Number 


X X X 


X 














00 - 6ms 

01 - 6ms Stepping Rates 




10 - 10ms 

11 - 20ms 

1 - Verify on last track 




- No verify 

1 - Head load at beginning 




- Do not load head at beginning 
RESTORE 







Figure 3-10. FD1771 RESTORE Command. 



7 6 


5 4 3 2 1 





1 X X X X 























< — Bit Number 



00 - 6ms 

01 - 6ms 

10 - 10ms 

11 - 20ms 



Stepping 
Rates 



- No verify 

1 - Verify on last track 

- Do not load head at beginning 

1 - Load head at beginning 

SEEK 



Figure 3-11. FD1771 SEEK Command. 



interrupt is generated at the comple- 
tion of this command. Figure 3-12 il- 
lustrates the command register bit con- 
figuration for a STEP command. 



3-54. STEP-IN 

The STEP-IN command causes the FD1771 
to issue one stepping pulse such that 
the Read/Write head moves one track to- 
ward track 76. An interrupt is 
generated at the completion of this 



command. Figure 3-13 illustrates the 
command register bit configuration for 
a STEP-IN command. 



3-55. STEP-OUT 

The STEP-OUT command causes the FD1771 
to issue one stepping pulse such that 
the Read/Write head moves one track 
toward track 0. An interrupt is 
generated at the completion of this 
command. Figure 3-14 illustrates the 
command register bit configuration for 
a STEP-OUT command. 
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7 6 5 4 3 2 10 



< — Bit Number 



1 X X X X X 



00 - 6ms 

01 - 6ms 

10 - 10ms 

11 - 20ms 



Stepping Rates 



- No verify 

1 - Verify on last track 

- Do not load head at beginning 

1 - Load head at beginning 

- No update 

1 - Update track register 

STEP 



Figure 3-12. FD1771 STEP Command. 



7 6 5 4 3 2 10 <--- Bit Number 


1 X X X X 


X 
















00 - 6ms 

01 - 6ms Stepping Rates 




10 - 10ms 

11 - 20ms 

- No verify 




1 - Verify on last track 

- Do not load head at beginning 




1 - Load head at beginning 
- No update 




1 - Update track register 
STEP-IN 



Figure 3-13. FD1771 STEP-IN Command. 



3-56. READ 

When the READ command is issued to the 
FD1771, the following events occur. The 
Read/Write head is loaded, the Busy 
status bit is set; and when the ID 
field (with the correct track number, 
sector number, and CRC) is encountered, 
the data read from the disk data field 



is transferred to the DMA controller 
for routing. The Data Address Mark (AM) 
must be found within 28 bytes of the 
correct field; if not, the Record Not 
Found status bit is set and the opera- 
tion is terminated. When the first 
character or byte of data is shifted 
through the Data Shift Register (DSR) , 
it is transferred to the Data Register 
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(DR) and DRQ is generated. When the 
next byte is encountered in the Data 
Shift Register (DSR) , it is transferred 



to the DR and another DRQ 
If the DMA has not read 
contents of the DR before 
ter is transferred, that 
and the Last Data 



lost 
set. 
the 
CRC 



is generated. 

the previous 

a new charac- 

character is 

status bit is 



This sequence is repeated until 
entire data field is read. If a 
error occurs at the end of the data 



field, the CRC error Status bit is set 
and the command is terminated. 

When the read operation is complete, 
the type of Data Address Mark read in 
the data field is recorded in the 
Status Register. For a definition of 
the bits affected, see the Status 
Register description. Figure 3-15 
illustrates the command register bit 
configuration for a READ command. 



7 6 5 4 3 2 10 <— - Bit Number 


1 1 X X X X 


X 


. 














00 - 6ms 

01 - 6ms Stepping Rates 




10 - 10ms 

11 - 20ms 

- No verify 




1 - Verify on last track 

- Do not load head at beginning 




1 - Load head at beginning 
- No update 




1 - Update track register 
STEP-OUT 







Figure 3-14. FD1771 STEP-OUT Command. 



7 6 5 4 3 2 10 


< — Bit Number 

1 = HLD set active and HLD is sampled 
after 10ms delay 

= NON-IBM format (128 to 4096 bytes) 

1 = IBM format (128 to 1024 bytes) 

= Single record 

1 = Multiple redord 

Read command 


1 X X 1 


L 































Figure 3-15. FD1771 READ Command. 
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3-57. WRITE 



3-58. Read Address 



Upon receipt of the WRITE command, the 
Read/Write head is loaded (HLD active) 
and the Busy status bit is set. When 
the correct ID field is located, a DRQ 
is generated. After 11 bytes of the 
CRC field, Write Gate (WG) activates if 
the DRQ is serviced. If the Data Reg- 
ister has not been loaded, the command 
is terminated and the Lost Data status 
bit is set. If the DRQ has been ser- 
viced, WG activates and six bytes of 
zeroes are written on the diskette. 

The FD1771 proceeds to write the data 
field and generate DREQ to the DMA. If 
a Data request is not serviced in time 
for continuous writing, the Lost Data 
Status bit is set and a byte of zeros 
is written on the diskette, but the 
command is not terminated. When the 
last data byte is written, the two-byte 
CRC is computed internally and written, 
followed by a one byte gap of logic 
ones. The command is then terminated. 
Figure 3-16 illustrates the command 
register bit configuration for a WRITE 
command. 



When the Read Address command is is- 
sued, the read/write head is loaded and 
the Busy status bit set. The first ID 
field encountered is read and the six 
data bytes in this field are assembled 
and transferred to the data register. 
A DRQ is generated for each byte. The 
ID address field is shown in figure 
3-17. 

The FD1771 checks for validity and sets 
the CRC error status bit when a CRC er- 
ror is detected. The sector address of 
the ID field is written into the sector 
register. When the operation is com- 
plete, an interrupt is generated and 
the Busy status bit reset. Figure 3-18 
illustrates the command register bit 
configuration for a READ ADDRESS com- 
mand. 



3-59. Read Track 

The Read Track command is implemented 
in the same manner as the Read Address 
command except the Read Enable signal 



7 6 5 4 3 2 10 <— Bit Number 


1 1 X X ] 


L X 


X 








hata r\ c\rv 








AM(HEX) AM(HEX) 

00 - FB C7 ADDRESS 

01 - FA C7 MARK 

10 - F9 C7 DETERMINATION 

11 - F8 C7 FIELD 

1 = HLD Set active and HLD is sampled 




after 10ms delay 
= Non IBM format (16-4096 bytes) 




1 = IBM format (128-1024 bytes) 
= Single record 




1 = Multiple record 
WRITE COMMAND 







Figure 3-16. FD1771 WRITE Command. 
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activates coincident with the leading 
edge of the first Index Pulse detected. 
Reading continues until the next Index 
pulse (indicating a complete disk revo- 
lution has occured) and then deacti- 
vates. Each byte read is assembled and 
transferred to the Data Register and a 
DRQ is generated. When bit of the 
command is 0, the accumulation of 
bytes is synchronized to each address 
mark read. Interrupt is activated at 
the completion of the command. The 
command register bit configuration for 
a READ TRACK command is shown in figure 
3-19. 



3-60. Write Track 

The Write Track command is initiated by 
loading the Read/Write head and setting 
the Busy status bit. Writing on the 
disk occurs coincident with the leading 
edge of the index pulse and terminates 
at the next index pulse. Data Request 
is activated with the receipt of the 
Write Track command, but no writing 
occurs until the first byte is read 
into the Data Register. If the Data 
Register is not loaded by the arrival 
of the first index pulse, the operation 
is terminated and interrupt activated. 











BYTE # 


1 


2 


3 


4 


5 


6 




ID 

ADDRESS 

FIELD 


Track 
Address 


Zeroes 


Sector 
Address 


Sector 
Length 


CRC 
1 


CRC 
2 









Figure 3-17. ID Address Field Data Bytes. 



7 


6 


5 4 3 


2 


1 





< — Bit Number 
Read Address 


1 


1 


ofo" 





1 



































Figure 3-18. FD1771 READ ADDRESS Command. 



READ TRACK COMMAND 
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Figure 3-19. FD1771 READ TRACK Command. 
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If, once writing is instituted, a byte 
is not present in the Data Register 
when required, a byte of zeros is sub- 
stituted. Address marks and CRC char- 
acters are written on the disk by de- 
tecting certain data patterns in the 
write data stream as shown in table 
3-7. The CRC generator is initial il zed 
when any data byte from F7 to FE is 
about to be transferred from the Data 
Register to the Data Shift Register. 



3-61 . Force Interrupt 

This command can be loaded into the 
command register at any time. If a 
command is being executed (Busy Status 
Bit set), that command is terminated 
and an interrupt generated upon the 
selected condition programmed by bits 
through 3. Figure 3-20 illustrates 
the command register for a FORCE 
INTERRUPT command. 



TABLE 3-7. DATA PATTERN. 



Data 






Pattern 


Interpretation 


Clock 


(HEX) 




Mark 


F7 


Write CRC Character 


FF 


F8 


Data Address Mark 


C7 


F9 


Data Address Mark 


C7 


FA 


Data Address Mark 


C7 


FB 


Data Address Mark 


C7 


FC 


Index Address Mark 


D7 


FD 


Spare 




FE 


ID Address Mark 


C7 



3-62. STATUS REGISTER 

The Status Register is located at 
address port 00, and at the receipt 
of any command, except Force Interrupt, 
the Busy status bit is set. Also, the 
rest of the status bits are updated or 
cleared for the new command. When the 
Force Interrupt Command is received and 
a command is being executed, the Busy 
status bit is reset and the other 
status bits remain unchanged. If no 
command is being executed when a Force 
Interrupt is received, the Busy status 
bit is reset and the other status bits 
are updated or cleared. Figure 3-21 
illustrates the bit configuration of 
the Status Register. 



76543210 <--- Bit Number 



1 1 1 X X X X 



1 = Not Ready to Ready 
transition 

1 = Ready to Not Ready 
transition 

1 = Index pulse 

1 = Immediate interrupt 

Force interrupt 



Interrupt 
Conditions 



Figure 3-20. FD1771 FORCE INTERRUPT Command. 
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FIGURE 3-21. FD1771 Status Register. 
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CHAPTER 4 
THEORY OF OPERATION 



4.1 GENERAL INFORMATION 

The FDC board accepts commands and 
parameters from the host system, 
interprets the commands and produces 
control signals to initiate oprations 
in the LSI circuits (FD1771A Floppy 
Disk Formatter/Controller and Am9517 
Multimode DMA Controller), outputs 
operating signals to the disk units, 
interfaces disk data between the disk 
units and FD1771, and inputs status 
information from the disk units. 



The functions to format disk data, 
transfer data between the FDC board and 
disk units, control 
operations, and transfer 
the FDC and Host memory 
by the DMA controller, 
descriptions of these 
not included herein. 



disk unit 

data between 

are performed 

Functional 

operations are 

Refer to the 



appropriate 
references 
manual ) . 



data 
at the 



sheets, 
front 



of 



(See 
this 



All operations are under control of the 
on-board CPU and firmware. A block 
diagram of the Am95/6110 FDC board is 
shown in figure 4-1. 



4-2. INSTRUCTION EXECUTION 

Operations on the FDC board are the 
result of recognizing the command and 
implementing on-board firmware 
routines. One command is described in 
detail. The remaining commands are 
executed in a similar manner and the 
detailed descriptions are not included. 



4-3. READ A SECTOR OPERATION 

The host CPU sends the page segment 
parameter to RO, the MSB of the data 
address (in master memory) to Rl, and 



the LSB of the data address to R2. The 
command and sector count is then sent 
to R3. 

The receipt of data into R3 causes the 
COMMAND-IN flip-flop (U7) to set. The 
status register is cleared; the board 
is in busy state. When in its idle 
state, the on-board CPU polls the state 
of this flip-flop. When the flip-flop 
sets, the on-board CPU inputs the 
command from R3 and determines the 
required operation. 

In this case, a READ operation is 
found. The data in RO, Rl, and R2 are 
retrieved and used to set-up the DMA 
controller. The DMA controller can be 
set to transfer either single bytes or 
blocks of 128 bytes for each DMA 
request. For this example, the DMA 
controller is set for single-byte DMA. 

The on-board CPU then loads the track, 
sector, and command into the FD1771 
controller. Unit, track, and sector 
parameters are sent from the host CPU 
during a previous SETPAR command. 

When the sector is reached and a byte 
is assembled, the DREQ signal is 
raised. This is converted into the DMA 
REQUEST signal for the Am9517 DMA 
controller. The Am9517 sends an HREQ 
to the on-board CPU and a bus request 
is sent to the host system. When the 
master bus is obtained, the DMA 
controller generates a DMA acknowledge. 
This signal is also the chip select 
signal for the FD1771. The byte of 
data is transferred to main memory. 
When the byte is transferred, the DREQ 
signal is dropped and the Am9517 
controller releases the CPU from HOLD. 

Following transfer of the whole sector, 
the FD1771 generates an INTRQ to the 
on-board CPU. The on-board CPU is 
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interrupted and it then retrieves the 
drive status information from the 
FD1771 and places this information in 
mail-box register R4. Also, bit-7 of 
R4 is sent to signify that the 



controller is no longer busy. If bit-6 
of the previous Unit Code received was 
set, an interrupt request is sent to 
the host system. The on-board CPU 
returns to the Idle State. 
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FIGURE 4-1. Floppy Disk Controller Functional Block Diagram 
(Control Signals are not Shown). 
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CHAPTER 5 
SERVICE INFORMATION 



5-1. INTRODUCTION 

This chapter provides information on 
service and repair assistance, user 
replacement parts and service diagrams 
for the AMC 95/6110 Single Density 
Floppy Disk Controller. 



5-2. SERVICE AND REPAIR 
ASSISTANCE 

If it is necessary to return the AMC 
915/6110 Floppy Disk Controller board 
to Advanced Micro Computers for service 
or repair, contact the Service Manager 
for OEM Products at the telephone 
number listed below. A Return Material 
Authorization number must be obtained 
prior to shipment. When the reshipment 
is due to the board being damaged 
during shipment from AMC, or the board 
is out of warranty, a purchase order is 
required to complete the repair. 



Repackage the board in the original 
packing material or an equivalent 
substitute, and enclose in a corrugated 
carton suitable for shipping. Seal the 
shipping carton securely, mark it 
FRAGILE, and address to: 



Advanced Micro Computers 
Service Manager, OEM Products 
3340 Scott Boulevard 
Santa Clara, California 95051 

TELEPHONE: (408) 988-7777 



TOLL FREE: 
800-672-3548 
800-538-9791 



Cal i form' a 
U.S.A. (except 
California) 



5-3. USER REPLACEABLE PARTS 

Listings of all user replaceable parts 
is provided in table 5-1. Figure 5-1 
is the component location diagram. 



5-4. SERVICE DIAGRAMS 

The Floppy Disk Controller component 
locations are shown on the assembly 
drawing, figure 5-1. Part numbers for 
the components shown on the assembly 
drawing are listed in table 5-1. 



Schematic diagrams of the 
Controller are shown in 
through 5-6. Active-low 
signals are specified by 
(*) following the signal name. 



Floppy Disk 

figures 5-2 

(logical 

an asterisk 
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TABLE 5-1. USER REPLACEABLE PARTS. 



AMC Part 


Description 


Location 




Number 








200032 


Integrated c 


ircuit, Type 74LS04 


Ul, 10, 62 




200081 


Integrated c 


ircuit 


, Type 74LS164 


U2, 5 




200018 


Integrated c 


ircuit 


, Type 74LS244 


U3, 27, 34 




200084 


Integrated c 


ircuit 


, Type 74LS109 


U4 




200045 


Integrated c 


ircuit 


, Type 74LS00 


U6 




200004 


Integrated c - 


ircuit 


, Type 74LS74 


U7, 13,38, 39, 44, 


68 


200001 


Integrated c 


ircuit 


, Type 74LS08 


U8, 17, 61 




200003 


Integrated c - 


ircuit 


, Type 74LS32 


U9, 18, 19, 55, 64 




210008 


Integrated c 


rcuit 


, Type 7407 


U12, 63 




200021 


Integrated c" 


ircuit 


, Type 74LS253 


U14, 15 




220027 


Integrated c" 


rcuit 


, Type 74S257 


U16 




200057 


Integrated c 


* re u i t 


, Type 74LS11 


U20 




220022 


Integrated c 


rcuit 


, Type 74S05 


U21 




220017 


Integrated c 


rcuit 


Type 74S04 


U22 




200052 


Integrated ci 


rcuit 


, Type 74LS138 


U23, 24, 45 




200075 


Integrated ci 


re u i t j 


Type 74LS373 


U25, 35 




280006 


Integrated ci 


rcuit 


, Type 8304 


U26 




200078 


Integrated ci 


rcuit , 


Type 74LS273 


U28, 29 




210007 


Integrated ci 


rcuit 


, Type 7483A 


U30, 36 




200016 


Integrated ci 


rcuit, 


Type 74LS240 


U31, 37, 41 




260028 


Integrated ci 


rcuit 


Type 8085 


U32 




200080 


Integrated ci 


rcuit, 


Type 74LS260 


U33 




260009 


Integrated ci 


rcuit , 


Type 9517 


U40 




200020 


Integrated ci 


re u i t , 


Type 25LS2521 


U42 




230012 


Integrated ci 


rcuit , 


Type 9114E 


1)49, 50 




280011 


Integrated ci 


rcuit, 


Type 8303 


U51, 52, 58, 67 




200085 


Integrated ci 


rcuit, 


Type 25LS2518 


U53 




220005 


Integrated ci 


re u i t , 


Type 74S139 


U54 




200082 


Integrated ci 


rcuit, 


Type 74LS670 


U56, 57 




260014 


Integrated ci 


rcuit, 


Type FD1771 


U60 




200083 


Integrated ci 


rcuit, 


Type 74LS123 


U65 




200041 


Integrated ci 


re u i t , 


Type 25LS2520 


U66 




200042 


Integrated ci 


rcuit, 


Type 74LS193 


U69 




200035 


Integrated ci 


rcuit, 


Type 74LS163 


U70 




220016 


Integrated ci 


rcuit, 


Type 74S240 


U59 




220002 


Integrated circuit, 


Type 74S00 


Ull 




450019 


24 Pin I.C. Socket 


U46, 47, 48 




450021 


40 Pin I.C. Socket 


U32, 40, 60 




690022 


Switch, Recess Rocker, 6 POS. 


U43 




340011 


Capacitor, Ceramic .l m f, 50V, 20% 


C2, 3, 4 




340002 


Capacitor, Tantalum, 22 TH f, 15V, 20% 






340047 


Capacitor, Tantalum, 4.7™f, 16V, 20% 


C25, 26 




310002 


Diode, IN914 


CR1, CR2 




630029 


Resistor, Carbon, IK, 1/4W, 5% 


Rl, 6, 7 14 




630017 


Resistor, Carbon, 4.7K, 1/4W, 5% 


R2, 3, 4, 10, 11 




630033 


Resistor, Carbon, 10K, 1/4W, 5% 


R5, 8, 9, 15 




630065 


Resistor, Carbon, 27K, 1/4W, 5% 


R12 




630063 


Resistor, Carbon, 47K, 1/4W,1 5% 


R13 
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TABLE 5-1. USER REPLACEABLE PARTS (Cont.). 



AMC Part 


Description 




Location 


Number 








630014 


Resistor, Network, 4.7K, 8 Pos. 


RPl, 


4, 5 


630057 


Resistor, Network, 4.7K, 6 Pos. 


RP2 




630056 


Resistor, Network, 4.7K, 10 Pos. 


RP3, 


6, 7 


630500 


Resistor, Network, 10K, 6 Pos. 


RP9 




630508 


Resistor, Network, IK, 6 Pos. 


RP8 




480011 


8MHz Clock, 0SC 


Yl 
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Figure 5-1. Am95/6110 Components Location. 
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Figure 5-2. Am95/6110 Schematic Sheet 1 
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Figure 5-3. Am95/6110 Schematic Sheet 2. 




Figure 5-4. Am95/6110 Schematic Sheet 3. 
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Figure 5-6. Am95/6110 Schematic Sheet 5. 
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